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MNE- 
MONIC 


OCTAL 
CODE 
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NAME 


PAGE 


00 


PS 




Program stop 


3-23 


AXi 


21 


jit 


Arithmetic right shift Xi, jk places 


3-32 


010 


RJ - 


K 


Return jump to K 


3-43 


AXi 


23 


Bj Xk 


Arithmetic right, shift Xk nominally Bj places to 


Xi 3-33 


Oil 


REC 


Bi+ K 


Reati Extended Care Storage 


3-46 


BXi 


10 


Xj 


Transmit Xj to Xi 


3-29 


012 


WEC 


Bj + K 


Write Extended Core Storage 


3-47 


BXi 


11 


Xj * Xk 


Logical product of Xj and Xk to Xi 


3-29 


013 


XJ 


B,i + K 


or contents of MA Central Exchange jump 


F-2 


BXi 


12 


Xj + Xk 


Logical sum of Xj and Xk to Xi 


3-30 


02* 


JP 


Bi+ K 


Jump to Bi + K 


3-44 


BXi 


13 


Xj - Xk 


Logical difference of Xj and Xlt to Xi 


3-30 


030" 


ZR 


Xj K 


Jump to K if Xj = 


3-44 


BXi 


14 


-Xk 


Transmit the comp. of Xlt to Xi 


3-30 


031 


NZ 


Xj K 


Jump to K if Xj j* 


3-44 


BXi 


15 


-Xlt * Xj 


Logical product of Xj and Xlt comp. to Xi 


3-31 


032 


PL 


Xj K 


Jump to K if Xj = plus (positive) 


3-44 


BXi 


16 


-Xlt + Xj 


Logical sum of Xj and Xlt comp. to Xi 


3-31 


033 


.« '^^ 


Xj K 


Jump to K if Xj = negative 


3-44 


BXi 


17 


-Xlt - Xj 


Logical difference of Xj and Xlt comp. to Xi 


3-32 


034 


m 


Xj K 


Jump to K if Xj is in range 


3-44 


CXi 


47 


Xlt 


Count the nuinber of I's in Xlt to Xi 


3-28 


035 


OR 


Xj K 


Jump to K if Xj is out of range 


3-44 


DF*t 


036 


Xj K 


Jump to K if Xj is definite 


3-44 


036 


DP 


Xj K 


Jump to K if Xj is definite 


3-44 


DXi 


32 


Xj + Xk 


Floating DP sum of Xj and Xlt to Xi 


3-38 


037, 


ID 


Xj K 


Jump to K if Xj is indefinite 


3-44 


DXi 


33 


Xj - XHt 


Floating DP difference of Xj and Xk to Xi 


3-38 


04 ~ 


EQ 


Bi Bj K 


Jump to K if Bi = Bj 


3-45 


DXi 


42 


Xj *xnt 


Floating DP product of Xj and Xlt to Xi 


3-41 


05 


NE 


Bi Bj K 


Jump to K if Bi / Bj 


3-45 


EQ* 


04 


Bi Bj K 


.lump to K if Bi = Bj 


3-45 


06 


GE 


Bi Bj IC 


Jump to K if Bi 2 Bj 


3-45 


FXi 


30 


Xj + Xk 


Floating sum of Xj and Xk to Xi 


3-37 


07 , 


LT 


Bi Bj K 


Jump to K if Bi <Bj 


3-45 


PXi 


31 


Xj - Xk 


Floating difference of Xj and Xlt to Xi 


3-37 


10 


BXi 


Xj 


Transmit Xj to Xi 


3-29 


FXi 


40 


Xj * Xlt 


Floating product of Xj and Xk to Xi 


3-40 


11 


BXi 


Xj *Xk 


Logical Product of Xj & Xlt to Xi 


3-29 


FXi 


44 


Xj / Xlt 


Floating divide Xj by Xk to Xi 


3-41 


12 


BXi 


Xj + Xlt 


Logical sum of Xj & Xlt to Xi 


3-30 


GE* 


OG 


Bi Bj K 


Jump to K if Bi ^ Bj 


3-45 


13 


BXi 


Xj - Xk 


Logical difference of Xj & Xlt to Xi 


3-30 


ID** 


037 ■ 


Xj K 


Jump to K if Xj is indefinite 


3-44 


14 


BXi 


-Xlt 


Transmit the comp. of Xlt to Xi 


3-30 


IR** 


034 


Xj K 


Jump to K if Xj is in range 


3-44 


15 


BXi 


-Xk » Xj 


Logical product of Xj & Xlt comp, to Xi 


3-31 


IXi 


36 


Xj + K 


Integer sum of Xj and Xlt to Xi 


3-28 


16 


BXi 


-Xk + Xj 


Logical sum of Xj & Xlt comp. of Xi 


3-31 


DCi 


37 


Xj - Xk 


Integer difference of Xj and Xlt to Xi 


3-28 


17 


BXI 


-Xk - Xj 


Logical difference of Xj & Xk comp to Xi 


3-32 


JP* 


02 


Bi + K 


Jump to Bi + K 


3-44 


20 


LXi 


jk 


Left shift Xi, jk places 


3-32 


LT* 


07 


Bi Bj K 


Jump to K if Bi < Bj 


3-45 


21 


AXi 


jit 


Aritlnnetic right shift Xi. jk places 


3-32 


LXi 


20 


jit 


Left shift Xi, jk places 


3-32 


22 


LXI 


Bj Xk 


Left shift Xk nominally Bj places to Xi 


3-33 


LXi 


22 


Bj Xlt 


Loft shift Xlt nominally Bj places to Xi 


3-33 


23 


AXi 


Bj Xk 


Aritlunetie right shift Xk nominally Bj places to Xi 


3-33 


MXi 


43 


jit 


Form mask in Xi; jk bits 


3-36 


24 


NXi 


Bj Xk 


Normalize Xk in Xi and Bj 


3-34 


NE* 


05 


Bi Bj K 


Jump to K if Bi # Bj 


3-45 


25 


ZXI 


Bj Xlc 


Round and normalize Xk in Xi and Bj 


3-34 


NG** 


033 


Xj K 


.lump to K if Xj = negative 


3-44 


26 


UXI 


Bj Xk 


Unpack Xk to Xi and Bj 


3-35 


NO 


46 




No operation (Pass) 


3-23 


27 


PXi 


Bj Xk 


Pack Xi from Xk and Bj 


3-36 


NXi 


24 


Bj Xk 


Normalize Xlt in Xi and Bj 


3-34 


30 


FXi 


Xj + Xk 


Floating sum of Xj and Xk to Xi 


3-37 


NZ** 


031 


Xj K 


Jump to !■: if Xj ji 


3-44 


31 


PXI 


Xj - Xlc 


Floating difference Xj and Xlt to Xi 


3-37 


OR** 


035 


Xj K 


Jump to K if Xj is out of range 


3-44 


32 


DXi 


Xj + Xk 


Floating DP sum of Xj and Xlt to Xi 


3-38 


PL** 


032 


Xj K 


Jump to K if Xj = plus (positive) 


3-44 


33 


DXi 


Xj - Xlt 


Floating DP difference of Xj and Xk to Xi 


3-38 


PS 


00 




Program stop 


3-23 


34 


HXi 


Xj + Xk 


Round floating sum of Xj and Xk to Xi 


3-38 


PXi 


27 


Bj Xk 


Pack Xi from Xlt and Bj 


3-36 


35 


RXi 


Xj-Xk 


Round floating difference of Xj and Xk to Xi 


3-39 


RE 


Oil 


Bj + K 


Read extended core 


3-46 


36 


rxi 


Xj + Xk 


Integer sum of Xj and Xk to Xi 


3-28 


RJ 


010 


K 


Return jump to K 


3-43 


37 


IXi 


X] - Xk 


Integer difference of Xj and Xlt toXi 


3-28 


RXi 


34 


Xj + Xk 


Round floating sum of Xj and Xk to Xi 


3-38 


40 


FXi 


Xj> Xk 


Floating product of Xj and Xk to Xi 


3-40 


RXi 


35 


Xj - Xlt 


Hound floating difference to Xj and Xk to XI 


3-39 


41 


RXi 


Xj * Xk 


Round floating product of Xj and Xk to Xi 


3-40 


HXi 


41 


Xj * Xk 


Hound floating product toXj and Xk to Xi 


3-40 


42 


DXi 


Xj t Xk 


Floating DP product of Xj and Xk to Xi 


3-41 


HXi 


45 


Xj / Xlt 


Hound floating divide Xj by Xk to Xi 


3-42 


43 


MXi 


jit 


Form mask in Xi, jk bits 


3-36 


SAi 


50 


Aj + K 


■ Set Ai to Aj + K 


3-24 


44 


FXi 


Xj / Xk 


Floating divide Xj by Xlt to Xi 


3-41 


SAi 


51 


Bj + K 


Set Ai to Bj + K 


3-24 


45 


HXI, 


Xj / Xlt, 


Round floating divide Xj by Xlt to Xi 


3-42 


SAi 


52 


Xj + K 


Set Ai to Xj + K 


3-24 


46 


NO, ■■ 




No operation (Pass) 


3-23 


SAi 


53 


Xj + Bk 


Set Ai to Xj + Bk 


3-24 


47 


CXi 


Xk 


Count the number of I's in Xlt to Xi 


3-2B 


SAi 


54 


Aj + Bk 


Set Ai to Aj + Bk 


3-24 


50 


SAi 


Aj + K 


Set Ai to Aj + K 


3-24 


SAi 


55 


Aj - Bk 


Set Ai to Aj - Bk 


3-24 


51 


SAi 


Bj + K 


Set Ai to Bj + K 


3-24 


SAi 


58 


Bj + Bk 


Set Ai to Bj + Bk 


3-24 


52 


SAi 


Xj + K 


Set Ai to Xj + K 


3-24. 


SAi 


57 


Bi - Bk 


Sot Ai to Bj - Bk 


3-24 


53 


SAi 


Xj + Bk 


Set Ai to Xj + Bk 


3-24 


SBi 


60 


Aj + K 


Set Bi to Aj + K 


3-26 


54 


SAi 


Aj + Bk 


Set Ai to Aj + Bk 


3-24 


SBi 


61 


Bj + K 


Set Bi to Bj + K 


3-26 


55 


SAi 


Aj - Bk 


Set Ai to Aj - Bk 


3-24 


SBi 


62 


Xj + K 


Set Bi to Xj + K 


3-26 


50 


SAi 


Bj + Bk 


Set Ai to Bj + Bk 


3-24 


SBi 


63 


Xj, + Bk 


Set Bi to Xj + Bk 


3-26 


57 


SAi 


Bj - Bk 


Set Ai to Bj - Bk 


3-24 


SBI 


64 


Aj + Bk 


Set Bi to A} + Bk 


3-26 


60 


SBi 


Aj + K 


Set Bi to Aj + K 


3-26 


SBi 


65 


Aj - Bk 


Sot Bi to Aj - Bk 


3-26 


61 


SBi 


Bj + K 


Set- Bi to Bj + K 


3-26 


SBi 


BG 


Bj + Bk 


Set Bi to Bj + Bk 


3-26 


62 


SBi 


Xj + K 


Set Bi to Xj + K 


3-26 


SBi 


67 


Bj - Bk 


Set Bi to Bj - Bk 


3-26 


63 


SBi 


Xj + Bk 


Set Bi to Xj + Bk 


3-26 


SXi 


70 


Aj + K 


Sot Xi to Aj + K 


■ 3-26 


64 


SBi 


Aj + Bk 


Set Bi to Aj + Bk 


3-26 


SXi 


71 


BJ.+ K 


Set Xi to Bj + K ' 


3-26 


65 


SBi 


Aj - Bk 


Set Bi to Aj - Bk 


3-26 


SXi 


72 


Xj + I< 


Set Xi to Xj + K 


3-26 


66 


SBi 


Bj + Bk 


Set Bi to Bj + Bk 


3-26 


SXi 


73 


Xj + Bk 


Set Xi to Xj + Bk 


3-27 


67 


SBi 


Bj - Bk 


Set Bi to Bj - Bk 


3-26 


SXi 


74 


Aj + Bk 


Set Xi to Aj + Bk 


3-27 


70 


SXi 


Aj + K 


Set Xi to Aj + K 


3-26 


SXi 


75 


Aj - Bk 


Sol Xi to Aj - Bk 


3-27 


71 


SXi 


Bj + K 


Set Xi to Bj + K 


3-26 


SXi 


76 


Bj + Bk 


Set Xi to Bj + Bk 


3-27 


72 


SXi 


Xj + K 


Set Xi to Xj + K 


3-26 


SXi 


77 


Bj - Bk 


Sot Xi td Bj - Bk 


3-27 


73 


SXi 


Xj + Bk 


Set Xi to Xj + Bk 


3-27 


LJXi 


26 


Bj Xlt 


Unpacit Xk to Xi and Bj 


3-35 


74 


SXi 


Aj + Bk 


Set Xi to Aj + Bk 


3-27 


WE 


012 


Bj + K 


Write ex-tended core 


3-47 


75 


SXi 


Aj - Bk 


Set Xi to Aj - Bk 


3-27 


XJ 


OViS"t'- 


Bj + K 


or contents of MA Central Exchange jump 


F-2 


76 


SXi 


Bj + Bk 


Sot Xi to Bj + Bk 


3-27 


7M'"' 


030 


Xj K 


.lump to K if Xj = 


3-44 


77 


SXi 


Bj - Bk 


Set XI to Bj - Bk 


3-27 


ZXi 


25 


Bj Xk 


Round and normalize Xk in Xi and Bj 


3-34 



*Jump to K + Bi and Jump to K if Bi tests made in Increment unit. 

**Jump to K if Xj tests made in Long Add unit, 

***Included in 6700 or those Systems having the appLicahle Standard Options. 
Rev K 
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A CONTROL DATA 6000 SERIES COMPUTER SYSTEM 

Display console (foreground) - includes a keyboard for manual input and operator 
control and two 10- inch display tubes for display of problem status and operator 
directives. 

Mainframe (center) - contains 10 Peripheral and Control Processors, Central Pro- 
cessor, Central Memory, some I/O synchronizers. The main frame in this photo is ■ 
that of the 6600 Computer System; the main frames for the 6400, 6500 and 6700 systems I 
differ in physical appearance, depending on options included in the systems. ' 

CONTROL DATA 607 Magnetic Tape Transport (left front) - 1/2-inch magnetic tape 
units for suplementary storage; binary or BCD data handled at 200, 556, or 800 bpi. 

CONTROL DATA 626 Magnetic Tape Transport (left rear) - 1-inch magnetic tape 
units for supplementary storage; binary data handled at 800 bpi. 

CONTROL DATA 405 Card Reader (right front) - reads binary or BCD cards at 1200 
card per minute rate. 

Disk file (right rear) - supplementary mass storage device; holds 500 million bits of 
information. 



1. SYSTEM DESCRIPTION 



INTRODUCTION 

The CONTROL DATA® 6400, 6500, 6600, and 6700 Computer Systems are four large- I 
scale, solid-state, general- purpose digital computing systems. The advanced design 
techniques incorporated in these systems provide for extremely fast solutions to data 
processing, scientific, and control center problems, as well as multiprocessing, 
time- sharing, and management information applications. 

Each of the computing systems has at least eleven independent computers (Figure 1-1). 
Ten of these, constructed with the peripheral and operating system in mind, are Peri- 
pheral and Control Processors. Each of these ten has separate memory and can execute 
programs independently of each other or the Central Processor, 



CENTRAL 
PROCESSOR 
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SYSTEM) 



CENTRAL MEMORY 
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PERIPHERAL PROCESSORS (10) 
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w ^ ^ ^ ^, 



DATA CHANNELS 
(12) 



Figure 1-1. CONTROL DATA 6400/6500/6600/6700 Computer "Systems 
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The eleventh computer, the Central Processor, is a very high speed arithmetic device. 
The common element of the Peripheral and Control Processors and the Central Pro- 
cessor is a large Central Memory. 

In solving a problem, one or more Peripheral and Control Processors are used for 
high speed information transfer in and out of the system and to provide operator control. 
I A number of programs may operate concurrently by time-sharing the Central Processor. 
(To facilitate this, the Central Processor may operate in Central Memory only within 
address bounds prescribed by a Peripheral and Control Processor. ) Further concur- 
rency is obtained within the Central Processor by parallel action of various functional 
segm.ents. Sim.ilarly, Central Memory is organized in 32 logically independent banks 
of 4096 words (60-bit). Several banks may be in operation simultaneously, thereby 
minimizing execution time. The multiple operating modes of all segm.ents of the 
computer, in combination with high-speed transistor circuits, produce a very high 
over- all computing speed. 



LEVEL #1 
CONCURRENCY 

IN 
PROGRAMS 



fDtSK PROGRAM A 
riAPE PROGRAM 
^DISPLAY PROGRAM 
^DISK PROGRAM B 
/DISK PROGRAM C 



CENTRAL PROGRAM 



LEVEL #2 
CONCURRENCY 

IN 
I FUNCTIONS * 



^CENTRAL MONITOR PROGRAM 
VDISK PROGRAM D 
^REAL-TIME COMMUNICATIONS PROGR 
VcARD READERS 8 PRINTERS PROGRAM 
^REAL-TIME SEQUENCE PROGRAM 




LEVEL # 3 
CONCURRENCY 
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Figure 1-2. Concurrent Operations in the 6400/6500/6600/6700 
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The Peripheral and Control Processor input/output facility provides a flexible arrange- 
ment for very high speed communication with a variety of I/O devices. Some of the I 
I/O devices available are listed below. I 

• Console Display: a cathode ray tube console with manual keyboard. This 
program- controlled unit displays problem status on two cathode ray tubes 
and handles operator directives from an alphanumeric keyboard similar 
to a standard typewriter keyboard, 

• Disk Systems: mass storage disk files providing nominal storage of 500 
million bits or 1. 3 billion bits. 

• Magnetic Tape Transports: 1/2 or 1-inch magnetic tape units which handle I 
binary data recording at 800 bits per inch on tapes up to 2400 feet long. 

• Satellite Coupler: a systems expansion device which permits direct 
connection between any two 6400 or 6600/6700 systems via two standard I 
12-bit bidirectional data channels. 

• Data Channel Converter: a device which permits the systems to use I 
CONTROL DATA 3000 Series peripheral equipment. Examples of available 
3000 Series peripheral equipment are card equipment (readers /punches), 
magnetic tape equipment, and line printers. 



Refer to the 6000 Series Peripheral Reference Manual for additional 
external equipment information. 



SYSTEMS CHARACTERISTICS SUMMARY 



I 



The following summary lists characteristics of the 6400, 6500, 6600, and 6700 I 

Computer Systems. Where characterics differ between the systems, differences are 
noted; otherwise, characteristics listed are common to all Systems. 
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System Characteristics 

• Large-scale, general- purpose computer system 

• 11 independent computers; 12 in the Dual Processor 6500 and 6700 systems. 
1 Central Processor (60-bit); 2 Central Processors in the 6500 and 
6700 system 

10 Peripheral and Control Processors (12-bit) 
Central Memory (60- bit) 
Display console and keyboard 

• System communicates with a variety of external equipment 

Disk files 
Magnetic tapes 
Card equipment 
Printers 

• Central Memory common to the system computers 

• Maximum Central Memory storage capability 131, 072 words (60-bit) 

I Major Cycle = 1000 nsec 

Minor Cycle = 100 nsec 
Memory organized in 32 banks of 4096 words 
Multiphase 

• Central Processor instructions 

Arithmetic, logical, indexing, branch 

• Peripheral and Control Processor instructions 

Add/ Subtract, logical, input / output, access to Central Processor 
and Central Memory 

• Each Peripheral and Control Processor has 12-bit 4096-word memory 

• Solid-state system 

Transistor logic 

Central Processor Characteristics 

I 6600 and 6700 

• 10 arithmetic and logical units 

Add Shift 

Multiply Branch 

Multiply Boolean 

Divide Increment 

I Long add Increment 
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Additional 6400 type unified arithmetic section operating in sequential 
manner (6 700 only). 

24 operating registers for functional units 

8 operand (60-bit) 

8 address (18-bit) 

8 increment (18-bit) 
8 transistor registers (60-bit) hold 32 instructions (15-bit) or 16 instruc- 
tions (30-bit) or a combination of the two for servicing functional units. 



6400 and 6500 

• Unified arithmetic section, operating in sequential manner (one per 
processor in 6500) 

• 24 operating registers (one set per processor in 6500) 

8 operand (6 0- bit) 
8 address (18-bit) 
8 increment (18- bit) 

• Instruction Buffer register (60- bit) 

Common Central Processor Char acteristics 

• Floating point arithmetic 

Single and double precision 
Optional rounding and normalizing 

• Format 

Integer coefficient - 48 bits 
Biased exponent - 11 bits (2 ) 
Coefficient sign - 1 bit 

• Fixed point arithmetic (subset of floating point arithmetic) 

Full 60- bit add /subtract 

• Controlled and started by Peripheral and Control Processors 

• Addresses in Central Memory relative 

Peripheral and Control Processor Characteristics 

• 10 identical processors (characteristics as listed are per processor 
except as noted) 

• 4096-word magnetic core memory (12-bit) 

• Random access, coincident - current 

Major Cycle = 1000 nsec 
Minor Cycle = 100 nsec 
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• 12 input /output channels 

All channels common to all processors 

Maximum transfer rate per channel - one word /major cycle 

All 12 channels may be active simultaneously 

All channels 12-bit bidirectional 

• Real-time clock (period = 4096 major cycles) 

• Instructions 

Add /Subtract 

Logical 

Branch 

Input /Output 

Central Processor access 

Central Memory access 

• Average instruction execution time = two major cycles 

• Indirect addressing 

• Indexed addressing 

Central Memory Characteristics 

• 131, 072 words (maximum size) 

• 60- bit words 

• Memory organized in 32 logically independent banks of 4096 words with 
corresponding multiphasing of banks; (32 banks is maximum memory size) 
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Figure 1-3, Block Diagram of 6600 System 
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« Random access, coincident- current, magnetic core 

• One major cycle for read- write 

» Maximum, memory reference rate to all banks - one address /minor 
cycle 

e Maximum rate of data flow to /from memory - one word/minor cycle 

Display Console Characteristics 

• Two display tubes 

• Modes 

Character 
Dot 

« Character size 

Large - 16 characters /line 
Medium - 32 characters /line 
Small - 64 characters /line 

• Characters 

26 alphabetic 

10 numeric 

11 special 
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SYSTEMS OPTIONS 

The foregoing summary of characteristics assumes a 6400, 6500, 6600, or 6700 
system with 10 Peripheral and Control Processors, a Central Processor (except for 
the 6500 and 6700 system, which have two Central Processors), and Central Menaory 
with 131,072 words (60-bit) of magnetic core storage. 

Options listed below are available within each system unless otherwise noted. 

• Central Memory with 131, 072 words (6 0- bit) of magnetic core storage. 

• Central Memory with 98, 304 words (60-bit) of magnetic core storage 
(refer to the publications for Standard Option 10180-1 and 10178-1). 

• Central Memory with 65, 536 words (60-bit) of magnetic core storage, 
(This is the minimum Central Memory size available for the 6500 Computer 
System.. ) 

• Central Memory with 49, 152 words (60-bit) of magnetic core storage 
(refer to the publications for Standard Option 10179-1 and 10177-1). 

• Central Memory with 32, 768 words (60-bit) of magnetic core storage. 

• Extended Core Storage (Refer to ECS Reference Manual) available in the 
following sizes: 

125, 952 words (60-bit) 
251, 904 words (60-bit) 
503, 808 words (60-bit) 

1, 007, 616 words (60-bit) 

2, 015,232 words (60-bit) 

• Extended Core Storage Controller: Couples up to 2, 015, 232 words of 
Extended Core Storage from one to four 6400, 6500, 6600, or 6700 central 
computer(s) or Augmented I/O Buffer and Control unit(s) in any combination. 

• Augmented l/O Buffer and Control: includes 16, 384 words (60-bit) of 
magnetic core storage and 10 Peripheral and Control Processors with 
storage. 

• Central Processor Monitor Facility (Central and Monitor Exchange Jump 
instructions): Refer to Appendix F. 
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A 6400 Central Computer with ECS Coupler, 7/ 8, or 9 Peripheral 
Processing Units, and 9, 10 or 11 Data Channels respectively. (See 
Appendix E for further information on 64XX-7, 64XX-8, and 64XX-9 
Computer Systems. ) 

Central Memory Access Priority (CMAP): Provides a Peripheral Processor 
with the ability to interrupt ECS transfers and also gives priority 
Peripheral Processors preference over non- priority Peripheral Processors 
in the execution of Central Read and Central Write instructions when ECS 
is inactive. CMAP is standard on the 6 700. 

Secondary Central Processor Unit (Standard Option 10174): Consists of 
a serial type Central Processor, including arithmetic and control functions 
able to communicate with Central Memory and Extended Core Storage. 
This option is included in the 6 700 Computer System. 

Additional Peripheral and Control Processors (Standard Option 10173): 
Provides 10 additional Peripheral and Control Processors and 12 addi- 
tional I/O channels to a 6 000 series computer. The resulting systems 
have 20 Peripheral and Control Processors, any one of which can access 
any one of 24 I/O channels. 



1-9 Rev K 




ORGANIZATION OF 6700 SYSTEM, SHOWING DATA CHANNELS AT 
PERIPHERY AND THEN MOVING INWARD TO PERIPHERAL 
PROCESSORS, CENTRAL MEMORY, AND DUAL CENTRAL PROCESSORS. 
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2. CENTRAL MEMORY 

ORGANIZATION 



Central Memory is organized into 32K, 49K, 65K, 98K, or 13 IK words (60- bit)' in 8, 
16, or 32 banks of 4096 words each. The banks are logically independent, and 
consecutive addresses go to different banks. Banks may be phased into operation at 
minor cycle* intervals, resulting in very high Central Memory operating speed. The 
Central Memory address and data control mechanisms permit a word to move to or 
from Central Memory every nainor cycle. 

ADDRESS FORMAT 

The location of each word in Central Memory is identified by an assigned number 
(address), which consists of 18 bits. Address formats are shown below for 8-bank 
(32K), 8-bank (49K), 16-bank (65K), 16-bank (98K), and 32-bank (131K) systems. 
Within the address format, the bank portion specifies one of 8, 16, or 32 banks; the 
12-bit address defines one of 4096 separate locations within the specified bank. 

8- Bank (32 K) Format 



8- Bank (49K) Format 
16-Bank (65K) Format 
16-Bank (98K) Format 
32-Bank (131K) Format 
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Addresses written or compiled in the conventional manner reference consecutive 
banks and hence make most efficient use of the bank phasing feature. 

CENTRAL MEMORY ACCESS 

References to Central Memory from all areas of the system (Central Processor and 
Peripheral and Control Processors) and Extended Core Storage go to a common 
address clearing house called a stunt box in the 6000/6700 and are sent from there to 
all banks in Central Memory. The stunt box accepts addresses from the various 
sources under a priority system and at a maximum rate of one address every minor 
cycle. 



*Minor cycle = 100 nsec. 
!=Bit 2llof bank address if 
(98K), depending on the Section/Chassis configuration selected. 



"*Bit 2llof bank address is supplied by either CM address bit 2 or 2 (49K) or 2'^^ 



+ 2 



1 
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An address is sent to all banks, and the correct bank, if free (the bank ignores the 
address if it is busy processing a previous address), accepts the address and indicates 
this to the stunt box. The associated data word is then sent to or stored from a central 
data distributor. The stunt box issues addresses at a maximum rate of one every 
minor cycle. 

The stunt box saves, in a hopper mechanism, each address that it sends to Central 
Memory and then reissues it (and again saves it) under priority control in the event 
it is not accepted because of bank conflict. The address issue- save process repeats 
until the address is accepted, at which time the address is dropped from the hopper 
and the read or store data word is distributed. A fixed time lapse from address-issue 
to the memory- accept synchronizes the action taken. 

The hopper (i. e. , a previously unaccepted address) has highest priority in issuing ad- 
dresses to Central Memory. The Central Processor and Peripheral and Control 
Processors (all 10 share a common path to the stunt box) follow in that order. In the 
6700, the 6400 type Central Processor is handled as if it were a Peripheral and 
Control Processor (i. e. , third priority). 

A data distributor which is common to all processors handles all data words to and 
from Central Memory (the Peripheral and Control Processors share one read path 
and one write path to the distributor). A series of buffer registers in the distributor 
provides temporary storage for words to be written into storage when the addresses 
are not immediately accepted because of bank conflict. 

Each group of four banks communicates with the distributor on separate 60-bit read 
and write paths, but only one word moves on the data paths at one time. However, 
words can move at minor cycle intervals between the distributor and Central Memory 
or distributor and address- sender. 

Data words and addresses are correlated by control information (tags) entered in the 
stunt box with the address. The tags define the address sender, origin/ destination 
of data, and whether the address is a Read, Write, or Exchange Jump address. 

MEMORY PROTECTION 

All Central Processor references to Central Memory for new instructions, or to read 
and store data, are made relative to the Reference Address. The Reference Address 
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defines the lower limit of a Central Memory program. Changes to the Reference 
Address permit easy relocation of programs in Central Memory. 

During an Exchange Jump, an 18-bit Reference Address and an 18-bit Field Length 
(parts of the Exchange Jump package) are loaded into their respective registers to 
define the Central Memory limits of the program initiated by the Exchange Jump. 

The relationship between absolute memory address, relative memory address. Refer- 
ence Address (RA), and Field Length (FL) is indicated in Figure 2-1. 
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Figure 2-1. Memory Map 

The following relationships must be true if the program is to operate within its bounds: 

RA < (RA + P) < (RA + FL) (Absolute Memory Addresses), or 
< P < FL (Relative Memory Addresses) 

NOTE 

1) FL is the number of 60-bit words comprising the program. It is not an ad- 
dress. 

2) To avoid possible "artificial" range faults, instructions should not be stored 
near the upper limit address of the Field Length. For example, using 
absolute address [(RA + FL) - 1] for an instruction produces a range fault 
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when the (look- ahead) Read Next Instruction occurs to (RA + FL). Data should 
always be stored in addresses near or approaching absolute location (RA + FL), 
rather than instructions. 

An optional exit condition (EM in the Exchange Jump package) allows the Central Pro- 
cessor to stop on a memory reference outside the limits expressed above. 
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3. CENTRAL PROCESSOR 



ORGANIZATION 

The Central Processor is an extremely high-speed arithmetic processor which com- 
municates only with Central Memory. It consists (functionally) of an arithmetic unit 
and a control unit. The arithm.etic unit contains all logic necessary to execute the 
arithmetic, manipulative and logical operations. The control unit directs the arithmetic 
operations and provides the interface between the arithmetic unit and Central Memory. 
It also performs instruction retrieving, address preparation/ memory protection, and 
data retrieving and storing. 

The Central Processor is isolated from the Peripheral and Control Processors and is 
thus free to carry on high-speed computation unencumbered by input/output require- 
ments. 

The organization of the Central Processor in the 6400 system differs from the 66 00/6 70o| 
Central Processor in two important respects: The 6500 system has two Central 
Processors, and both Central Processors are similar to the 6400 Central Processor. 
Central Processor differences are tabulated in Table 3-1. 

TABLE 3-1. CENTRAL PROCESSOR DIFFERENCES 



System 


Instruction Registers 


Arithmetic Section 


6400 and 6500 

Central 

Processors 


Instruction Buffer Register: 
holds one 60- bit instruction 
word. 


Unified Arithmetic Section: 
executes instructions in 
serial order. Requires no 
reservation control. 


6600/6700* 

Central 

Processor 


Instruction Stack: holds eight 
60- bit instruction words. 


Ten functional (arithmetic & 
logical) units : operate con- 
currently on unrelated instruc- 
tions. Require reservation 
control. 


*The 6700 also includes a 6400 type Central Processor. 
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With the exception of differences noted in the above table, the 6400 system Central 
Processor operation is identical to the operation of the Central Processor in the 
6600/6700 system. Each of the two 6500 Central Processors operate exactly like a 
6400 Central Processor. 

Programs for the Central Processor are held in Central Memory. A program begins 
with an Exchange Jump instruction from a Peripheral and Control Processor, This 
instruction specifies a segment of Central Memory for the central program, specifies 
the mode of exit (normal or error) of the program, and sets initial quantities in the 
X, B, and A registers. 

High speed in the Central Processor depends first on minimizing memory references. 
Twenty- four registers are provided to lower the Central Memory requirements for 
arithmetic operands and results. These 24 are divided into: 

• 8 address registers of 18 bits in length 

• 8 increment registers of 18 bits in length 

• 8 operand registers of 6 bits in length 

Eight 60-bit registers are provided to hold instructions (6600/6700), thereby limiting 
the number of mem.ory reads for repetitive instructions, especially in inner loops. 
Multiple banks of Central Memory are provided to minimize memory reference time. 
References to different banks of memory may be handled without waiting. 

Speed of operation in a conventional computer is limited by the serial manner in which 
instructions are executed. In the 6600/6700 Computer System, this operational speed 
is maximized by providing 10 arithmetic (functional) units and reservation control. 
Unrelated instructions are executed simultaneously, providing no conflicts exist in the 
arithmetic units. 

The 6400 or 6500, with its unified arithmetic section, executes instructions serially, 
with little concurrency. 
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Programs are written for the Central Processor in a conventional manner, specifying 
a sequence of arithmetic and control operations to be executed. Each instruction in a 
program is brought up in its turn from one of the instruction registers. These registers 
are filled from Central Memory in a manner sufficient to keep a reasonable flow of 
instructions available. 

A branch to another area of the program voids the old instructions in the registers 
and brings in new instructions. When a new instruction is brought up, a test is made 
to determine which of the 10 arithmetic units is needed, if it is busy, or if reservation 
conflict is possible. K the unit is free and no conflict is present, the entire instruction 
is given to the specified arithmetic unit for further action. Another instruction may 
then be brought up and issued. 

The original sequence of the program is established at the time each instruction is 
issued. Only those operations which depend on previous results prevent the issuing 
of instructions, and then only if the steps are incomplete. The reservation control 
keeps a running account of the address, increment, and operand registers and of the 
arithmetic units in order to preserve the original sequence. 

On occasion, a program may use an Increment Store instruction to modify the contents 
of a memory location holding a subsequent instruction. In the 6600/6 700, this modifi- I 
cation must occur before the instruction is read from Central Memory into the stack, 
for once in the stack the instruction can not be so modified. To avoid this potential 
problem, modification of any subsequent instruction words should be restricted to 
relative locations > (P) + 8. This rule applies equally to both "in- stack" loops and to 
other programs where, under certain conflict conditions, the Central Processor of 
the 6600/6700 may continue reading instruction words from Central Memory while | 

delaying execution of a previously issued Increment Store instruction. 

Nearly all Central Memory references for information or instructions are made on an 
implicit or secondary basis. Instructions are retrieved from memory only if the instruc- 
tion registers are nearly empty (or when ordered by a branch). Information is brought 
to or from the operand registers only when appropriate address registers are referenced 
during the course of a program. Such references are also accounted for in the reserva- 
tion control. 
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All Central Processor references to Central Memory are made relative to the lower 
boundary address assigned by a Peripheral and Control Processor. A Central Processor 
program may therefore be relocated in Central Memory by modifying the boundaries 
only. Any attempt by the Central Processor to reference memory outside of its bound- 
aries causes an immediate exit which can be readily examined by a Peripheral and 
Control Processor and displayed for the operator. 

The Exchange Jump instruction starts a central program. This instruction starts a 
sequence of Central Memory references which exchanges 16 words in memory with 
the contents of the address, increment, and operand registers of the Central Processor. 
Also exchanged are the program address, the Central Memory and Extended Core 
Storage boundaries, and choice of program exit. This instruction may be executed by 
any Peripheral and Control Processor and acts as an interrupt to an active central 
program as well as a start from an inactive state. The Exchange Jump is used by the 
operating system to switch between two central programs, leaving the first program 
in a usable state for later re-entry. 



CENTRAL PROCESSOR PROGRAMMING 

Central Processor program instructions are stored in Central Memory. A 6 0-bit mem- 
ory location may hold 60 data bits, four 15-bit instructions, two 30-bit instructions 
or a combination of 15 or 30-bit instructions. Figure 3-1 shows all instruction com- 
binations in a 60- bit word and the two instruction word formats. 

The Central Processor reads 60-bit words from Central Memory and stores them in 
an instruction stack which is capable of holding up to eight 60- bit words. 

Each instruction in turn is sent to a series of instruction registers for interpretation 
and testing and is then issued to one of 10 functional units for execution. The functional 
units obtain the instruction operands from and store results in the 24 operating 
registers. The reservation control records active operating registers and functional 
units to avoid conflicts and insure that the original instructions do not get out of order. 
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Functional Units 

The 10 functional units in the 6600/6700 system handle the requirements of the various I 
instructions. The Multiply and Increment units are duplexed, and an instruction is 
sent to the second unit if the first is busy. The general function of each unit is listed 
in Table 3-2. 



TABLE 3-2. FUNCTIONAL UNITS 



Unit 


General Function 


Branch 


Handles all jumps or branches from the program. 


Boolean 


Handles the basic logical operations of transfer, logical 
product, logical sum, and logical difference. 


Shift 


Handles operations basic to shifting. This includes left 
(circular) and right (end- off sign extension) shifting, and 
Normalize, Pack, and Unpack floating point operations. 
The unit also provides a mask generator. 


Add 


Performs floating point addition and subtraction on floating 
point numbers or their roundeci representation. 


Long add 


Performs one's complement addition and subtraction of 
60- bit fixed point numbers. 


Multiply 


Performs floating point multiplication on floating point 
numbers or their rounded representation. 


Divide 


Performs floating point division of floating point quantities 
or their rounded representation. Also sums the number of 
"I's" in a 60-bit word. 


Increment 


Performs one's complement addition and subtraction of 
18- bit numbers. 



Instruction Formats 

Groups of bits in an instruction are identified by the letters f, m, i, j, k, and K 
(Figure 3-1). All letters represent octal digits except K, which is an 18-bit constant. 
The f and m digits are the operation code and identify the type of instruction. In a 
few instructions the i designator becomes a part of the operation code. 
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In most 15-bit instructions the i, j, and k digits each specify one of eight operating 
registers where operands are found and where the result of the operation is to be 
stored. In other 15-bit instructions, the j and k digits provide a 6-bit shift count. 

In 30-bit instructions the i and j digits each specify one of eight operating registers 
where one operand is found and where the result is to be stored, and K is taken directly 
as an 18-bit second operand. 

NOTE 

In the 6600/6700, it is permissible to pack the upper- 
order 15 bits (fmij portion) of a 30-bit instruction in 
the lower- order 15-bit porition of an instruction word. 
When this 30-bit instruction is executed, the lower- 
order 15- bits of K are taken from the upper- order 
15 bits of the instruction word. 

In the 6400 and 6500, any 30-bit instruction with its 
fmij portion packed in the lower- order 15 bits of an 
instruction word will be executed as a STOP instruc- 
tion. 
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Figure 3-1. Central Processor Instruction Formats 

Operating Registers 

In order to provide a compact symbolic language, the 24 operating registers are identi- 
fied by letters and numbers: 

A = address register (AO, Al . . . A7) 
B = increment register (BO, Bl . . . B7) 
X = operand register (XO, XI . . . X7) 
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The operand registers hold operands and results for servicing the functional units. 
Five registers (XI - X5) hold read operands from Central Memory, and two registers 
(X6 - X7) hold results to be sent to Central Memory (Figure 3-2). Operands and results 
transfer between memory and these registers as a result of placing a quantity into a 
corresponding address register (Al - A7), 

Placing a quantity into an address register Al - A5 produces an immediate memory 
reference to that address and reads the operand into the corresponding operand register 
XI - X5. Similarly, placing a quantity into address register A6 or A7 stores the word 
in the corresponding X6 or X7 operand register in the new address. 
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Figure 3-2. Central Processor Operating Registers 
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The increment instructions place a result in address register Ai (where "i" = 0-7). in 
three ways: 

• By adding an 18-bit signed constant K to the contents of any A, B, or X 
register. 

• By adding the content of any B register to any A, B, or X register. 

• By subtracting the content of any B register from any A register or any 
other B register. 

The AO and XO registers are independent and have no connection with Central Memory. 
They may be used for scratch pad or intermediate results. Note the special use of AO 
and XO when executing Extended Core Storage comnaunication instructions. 

The B registers have no connection with Central Memory. The BO register is fixed to 
provide a constant zero (18-bit) which is useful for various tests against zero, provid- 
ing an unconditional jump modifier, etc. In general, the B registers offer means for 
program indexing. For example, B4 may store the number of times a program loop 
has been traversed, thereby providing a ternainal condition for a program exit. 

An Exchange Jump instruction from a Peripheral and Control Processor enters initial 
values in the operating registers to start Central Processor operation. Subsequent 
address modification instructions executed in the increment functional units provide 
the addresses required to retrieve and store data. 

Program Address 

An 18-bit P register serves as a program address counter and holds the address for 
each program step. P is advanced to the next program step in the following ways: 

1) P is advanced by one when all instructions in a 60-bit word have been 
extracted and sent to the instruction registers. 

2) P is set to the address specified by a Go To . . . (branch) instruction. If 
the instruction is a Return Jump, (P) + 1 is stored before the branch to 
allow a return to the sequence after the branch. 

3) P is set to the address specified in the Exchange Jump package. 

A.11 branch instructions to a new program start the program with the instruction located 
in the highest order position of the 60-bit word. 
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Exchange Jump 

A Peripheral and Control Processor Exchange Jump instruction starts or interrupts 
the Central Processor and provides Central Memory with the first address (which is 
the address in the Peripheral and Control Processor A register) of a 16-word package 
in Central Memory. The Exchange Jump package (Figure 3-3) provides the following 
information on a program to be executed: 



1) 
2) 
3) 
4) 
5) 
6) 
7) 
8) 
9) 
10) 



Program address (P) 

Reference Address for Central Memory (RAQ]y[) 

Field length of program for Central Memory (FLCM) 

Reference Address for Extended Core Storage (RAj^^g) 

Field length of program for Extended Core Storage (FL-pp^^ = 

Program exit mode (EM) ii^Cb; 

Initial contents of the eight A registers 

Initial contents of the eight X registers 

Initial contents of B registers Bl - B7 (BO is fixed at 0) 

Monitor Exchange (MA); Optional Instruction 



CENTRAL MEMORY 



PERIPHERAL AND 
CONTROL PROCESSOR 





A REGISTER 






CENTRAL MEMORY 
LOC. n 


y 




7 





LOC. n 
Loc. n + I 
Loc. n +2 
LOC. n +3 



_oa 



59 

MA= MONITOR ADDRESS 
P= PROGRAM ADDRESS 
RA= REFERENCE ADDRESS 
FL= FIELD LENGTH 



EM= EXIT MODE: 



OCTAL 

CONTENTS OF 

BITS 36-53, 

LOCATION n +3" 



000000 
010000 
020000 
030000 

040000 
050000 



070000 



A= ADDRESS REGISTERS 
B= INCREMENT REGISTERS 
X= OPERAND REGISTERS 

DISABLE EXIT MODE 

ADDRESS OUT OF RANGE 

OPERAND OUT OF RANGE 

ADDRESS OR OPERAND 

OUT OF RANGE 

INDEFINITE OPERAND 

INDEFINITE OPERAND OR ADDRESS 

OUT OF RANGE 

INDEFINITE OPERAND OR OPERAND 

OUT OF RANGE 

INDEFINITE OPERAND OR ADDRESS 

OUT OF RANGE OR OPERAND OUT 

OF RANGE 



Figure 3-3. Exchange Jump Package 



"S'A^^^r.ol^^ ^^\ ^^°° *^^ ""PP^"" *^^^^ """^ °^ RA(ECS) are not transferred to the 
RA(ECS) register. 
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The Central Processor enters the information about a new program into the appropriate 
registers and stores the corresponding and current information. from the interrupted pro- 
gram at the same 16 locations in Central Memory. Hence, the controlling information 
for two programs is exchanged. A later Exchange Jump may return an interrupted pro- 
gram to the Central Processor for completion. The normal relation of the A and X reg- 
isters (described earlier) is not active during the Exchange Jump so that the new entries 
in A are not reflected into changes in X. 

PROGRAMMING NOTE 

When an Exchange Jump interrupts the Central Processor, several 
steps occur to insure leaving the interrupted prograna in a usable 
state for re-entry: 

1) Issue of instructions halts after issuing all instructions 
from the current instruction word in the instruction stack. 

2) The Program Address register, P, is set to the address 
of the next instruction word to be executed. 

3) The issued instructions are executed, and then 

4) The parameters for the two programs are exchanged. 

A subsequent Exchange Jump can then re-enter the interrupted pro- 
gram at the point it was interrupted, with no loss of program continuity. 

To preserve the integrity of an "in-stack" loop (in the event of an 
Exchange Jump), it is illegal to modify the contents of any memory 
address which holds an executable instruction (or instruction word) 
contained within the loop. 

EXAMPLE: 




These instruction 
words in stack 
(from memory 
locations [Y + l] 
through [Y + 5] ) 
constitute a loop. 



After executing the 
lower instruction at 
[Y + 3], the contents 
of memory location 
[Y + l] differ from the 
contents of [Y + l] in 
the stack. If the Ex- 
change Jump comes 
in as indicated, sub- 
sequent reentry will 
call up the modified 
loop from memory, 
rather than the stack 
loop in its original 
un-modified form. 



Assume Exchange Jump- 
comes in at this point 
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All Central Processor references to Central Memory for new instructions, or to fetch 
and store data, are made relative to the Reference Address. This allows easy reloca- 
tion of a program in Central Memory. The Reference Address or beginning address 
and the Field Length define the Central Memory limits of the program. An Exit Selec- 
tion allows the Central Processor to stop on a memory reference outside these limits. 

The Program Address register P defines the location of a program step within the limits 
prescribed. Each reference to memory to fetch instructions is made to the address 
specified by P + RA. Hence program relocation is conveniently handled through a single 
change to RA. 

A P = condition specifies address zero and hence RA. This address is reserved for 
recording program exit (error) conditions and should not, therefore, be used to store 
data or instructions of a program. 

Exit Mode 

The Exit mode feature allows the programmer to select Exit or Stop conditions for the 
Central Processor. Exit selections are loaded into bits 36-53 of memory location "n+3" 
of the Exchange Jump package (Figure 3-3). When the Exchange Jump occurs to that 
package, the exit selections are stored in the Central Processor and the exit occixca_as 
soon as the selected condition is sensed. The Exit conditions, as stored in bits 36-53 
of address "n+3" in the Exchange Jump package, are shown below in octal format: 

EM = 000000 Disable Exit mode - no Exit selections made. 

010000 Address out of range - 

a) an attempt to reference either Central Memory 
or Extended Core Storage outside established 
limits, or 

b) the word count, [ (Bj) + K] , in an Extended Core 
Storage Communication instruction is negative. 

(For details on action when an address is out of range, 
refer to the Increment and Extended Core Storage instruc- 
tion descriptions. ) 

020000 Operand out of range - floating point arithmetic unit 

received an infinite operand (see Range Definitions 
under Floating Point Arithmetic following). 
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030000 Address or operand out of range 

040000 Indefinite operand - floating point arithmetic unit (Add, 

Multiply, or Divide) attempted to use an indefinite operand 
(see Range Definitions, page 3-17). 

050000 Indefinite operand or address out of range 

060000 Indefinite operand or operand out of range 

070000 Indefinite operand or operand or address out of range 

Typically, the Reference Address (RA) for any program is left cleared to all zeros. 
When an error exit is taken, the Central Processor records at RA the exit condi- 
tion (upper 2 octal digits only) and the Program Address at exit time (refer to the format 

below). 

NOTE 

The Exit condition(s) recorded at RA comprises all the 
Exit conditions detected since the last Exchange Jump, 
regardless of whether they were selected. Thus, com- 
binations of error Exit conditions (03, 05, 06 or 07) can 
appear at RA: 

a) When at least one Exit condition was selected and 
the selected condition plus another condition occur- 
red since the last Exchange Jump, or 

b) When more than one Exit condition was selected 
and each occurred in the same minor cycle. 

The contents of RA are then read up, interpreted as a Stop instruction, and the Central 

Processor stops. 



59 54 53 48 47 


30 


29 










X 

■ / 


X 

^— '■'- ' t 


X 


— 


-)^ 


-0 



STOP EXIT P ZEROS 

P = {P) + i; AT TIME OF ERROR EXIT. 

For error stops, (P) + 1 gives only an approximate location of the error since the Cen- 
tral Processor may have issued other instructions to the functional units (one of which 
may have been a branch) before the exit was sensed. 

On an Address Out of Range, hardware action differs from that outlined above. In some 
cases, a stop occurs when an address is out of bounds even though an Exit mode stop is 
not selected for this condition. Table 3-3 summarizes hardware action for operations 
which may reference addresses that are out of bounds. 
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TABLE 3-3. EXIT MODE: ADDRESS OUT OF BOUNDS 





HARDWARE ACTION 


OPERATION 


EXIT MODE SELECTED 


EXIT MODE NOT SELECTED 


RNI to an ad- 
dress that is 
out- of bounds 
(occurs when 
an instr. is 
located in 
absolute ad- 
dress (RA + 
FL) - 1). 


1. Detect error condition 

2. Clear P 

3. Stop by reading (RA) 

4. Write EM and (P) + 1 into RA 


1. Detect error condition 

2. Stop by reading (RA) 

3 . Nothing stored in RA 

4. (P) = out of range P or 
(P) + l 


Branch to an 
address that 
is out-of- 
bounds. 


1. Detect error condition 

2. Clear P 

3. Stop by reading (RA) 

4. Write EM and jump address + 1 in RA 


1. Detect error condition 

2 . Stop by reading (RA) 

3. Nothing stored in RA 

4. (P) = out of range P or 
(P) + 1 


Read 
Operand 


1. Detect error condition 

2. Clear P 

3. Stop by reading (RA) 

4. Write EM and (P) + 1 into RA 

5. (Xi) = (AAZ) 


1 . Detect error condition 

2. Read(RA) into Xi 

3. Continue program 


Write 
Operand 


1. Detect error condition 

2, Clear P 

3, Stop by reading (RA) 

4. Write EM and (P) + 1 into RA 


1 . Detect error condition 

2. Read (RA) , but (Xj) 
not stored; (X^) and 
(Ai) unchanged. 

3. Continue program 



Action After Exit Mode or Normal Stop 

Typically, a Peripheral and Control Processor periodically searches for an unchanging 
Central Processor Program Address register (any value) to determine if the Central 
Processor has stopped. Once it has been determined that the Central Processor has 
stopped, the examining Peripheral and Control Processor can transfer control to an error 
routine to determine the nature of the condition causing the Stop. Figure 3-4 illustrates 
sample steps for processing Central Processor stops (either Exit mode or normal). 
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Via P & CP, read 
CP Program 
Address Register 



I 1 

May be other 
' steps in this ' 
I routine | 



L 



Are (P) 

unchanged from 
last test? 



No 



Yes 



Are (P) = 0? 



No 



Yes 



Stop is due to an error 
and the error stop 
was selected. 



Examine (RA) to 
determine approxi- 
mate location of error- 
producing instruction. 



Yes 



Branch to Error 
Routine to Recover 
From Error. 



^ I 



Stop is due to either: 

1) Normal (instr. ) 
stop, or 

2) Stop because of 
RNI or Branch to an 
out-of-bounds address 
(with Exit mode un- 
selected). 



Branch to routine to 
determine nature of 
stop. 






Is stop due to an 
out-of-bounds error? 1 






No 



Take appropriate 
action for a stop 
condition. 



Figure 3-4. Detecting and Handling Central Processor Stops 
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Floating Point Arithmetic 

Format 

Floating point arithmetic takes advantage of the ability to express a number with the gen- 
eral expression kB , where: 

k = coefficient 

B = base number 

n = exponent, or power to which the base number is raised 

The base number is constant (2) for binary- coded quantities and is not included in the gen- 
eral format. The 60-bit floating-point format is shown below. The binary point is con- 
sidered to be to the right of the coefficient, thereby providing a 48-bit integer coefficient, 
the equivalent of about 14 decimal digits. The sign of the coefficient is carried in the 
highest order bit of the packed word. Negative numbers are represented in one's com- 
plement notation. 



COEFFICIENT 
SIGN 



59 58 



BIASED 
EXPONENT 



INTEGER 
COEFFICIENT 



48 



] [ 



48 47 



.10 



BINARY 
POINT 



The 11-bit exponent carries a bias of 2 (2000o) when packed in the floating point word 
(biased exponent sometimes referred to as characteristic). The bias is removed when 
the word is unpacked for computation and restored when a word is packed into floating 
format. Table 3-4 lists (in decimal and octalnotation) the complete range of permissible 
exponents and the octal form of the corresponding positive and negative floating point words . 



Thus, a number with a true exponent of 342 would appear as 2342; a number with a true 
exponent of -160 would appear as 1617. Exponent arithmetic is done in one's comple- 
ment notation. Floating point numbers can be compared for equality and threshold. 
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TABLE 3- 


-4. RANGE OF PERMISSfflLE EXPONENTS 






EXPONENT (n) 


REPRESENTATION OF kxE^^ (OCTAL) 


DECIMAL 


OCTAL 


POSITIVE 
COEFFICIENT 


NEGATIVE 
COEFFICIENT 


+1023 


+1777 


(infinite operand) 


3777 X X 


4000 X X 


+1022 

• 
• 


+1776 

• 




3776 X 


... X 


4001 X 


... X 


a 
• 

+1 


• 

+1 




2001 X 


... X 


5776 X 


• • • X 


+0 


+0 




2000 X 


... X 


5777 X 


> • • }i. 


-0 


-0 


(indefinite operand) 


1777 X 


• • • ^ 


6000 X 


■ • • -A. 


-1 

• 
• 


-1 

• 




1776 X 


• • • Ji. 


6001 X 


... X 


• 

-1023 


• 

-1777 




0000 X 


■ > • 2^ 


7777 X 


... X 



Normalizing and Rounding 

Normalizing a floating point quantity shifts the coefficient left until the most significant 
bit is in bit 47. Sign bits are entered in the low-order bits of the coefficient as it is 
normalized. Each shift decreases the exponent by one. 

A round bit is added (optionally) to the coefficient during an arithmetic process and has 
the effect of increasing the absolute value of the operand or result by one-half the value 
of the least significant bit. Normalizing and rounding are not automatic during pack or 
unpack operations so that operands and results may not be normalized. 

Single and Double Precision 

The floating point arithmetic instructions generate double- precision results. Use of un- 
rounded operations allows separate recovery of upper and lower half results with proper 
exponents; only upper half results can be obtained with rounded operations. 
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Double length registers appear as follows: 





MOST SIGNIFICANT 


BITS 




LEAST 


SIGNIFICANT BITS 




95 






48«47 








/ 




V 

UPPER HALF 
RESULT 




ii 

BINARY 
POINT 




V 

LOWER HALF 
RESULT 





Range Definitions 

A result with an exponent so large that it exceeds the upper linait of octal 3 777 (overflow 
case) is treated as an infinite quantity. A coefficient of allzeros and an exponent of octal 
3 777 or 4000 is packed for this case. An optional exit is provided when an attempt is 
made to use an infinite operand in the floating arithmetic units since its use maypropagate 
an indefinite result as shown in Table 3-5, No error exit occurs when an infinite or inde- 
finite result is generated in a functional unit. 

TABLE 3-5. INDEFINITE FORMS 



CO — 00 










: 


INDEFINITE 


CO -J- N = CO 


CO T- 00 










= 


INDEFINITE 


00 + N = oo 


CO • 










= 


INDEFINITE 


CO - N ; <D 


-H 










= 


INDEFINITE 


N -i- = to 


INDEFINITE 


+ ■- 


I ■ 


• (X) 


= 


INDEFINITE 


-T- 00 = 


CO + 00 










= 


CO 


• = 


op • 00 










z 


CO 


-r N = 


00 -f- 










- 


CO 


N -S- 00 = 




where: 


m 


= INFINITY, N = INTEGER, 










X 


= <o 1 


N 


OR 0. 





A result the exponent of which is less than the lower limit of octal 0000 (underflow case) 
is treated as a zero quantity. This quantity is packed with a zero exponent and zero co- 
efficient. No exit is provided for underflow. A result with an exponent of octal 0000 and 
a coefficient which is not zero is a non-zero quantity and is packed with a zero exponent 
and the non-zero coefficient. 
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Use of either infinity or zero as operands may produce an indefinite result. An exponent 
of octal 1777 and a zero coefficient are packed in this case, and an optional exit provided. 
Note that zero, infinite, and indefinite results are generated or regenerated in floating 
arithmetic operations only. The branch instructions test for infinite or indefinite quan- 
tities. 



In all floating arithmetic operations, an attempt to normalize an indefinite quantity re- 
turns the original quantity, e. g. , if the number 17770237. . .were to be normalized, the 
result would be the same as the original number. Note that Exit naode does not occur on 
detecting an indefinite quantity in the Shift Unit. 

Exit mode tests for infinite and indefinite operands are made only in the Floating Add, 
Multiply, and Divide Units. The 12 most significant bits of each operand are tested for 
these special forms. 

In the Multiply and Divide Units (but not in the Floating Add Unit) there is a special test 
for zero operands as determined by the 12 most significant bits. 



Thus the special operand forms (in octal) are: 

infinite operands 



3777X. 
4000X. 



X 
X 



1777X. 
6000X. 

OOOOX. 
7777X. 



X 
X 

X 
X 



(+«>) 

(-00) 

(+IND) "I 
(-IND) J 

(+0) ^ 

(-0) r 



indefinite operands 

zero operands for 
Multiply and Divide 
iinits only 



Whenever infinite, indefinite, or zero results are generated in accordance with the rules 
given in Table 3-5 and Appendix C, only the following octal words can occur as results: 

37770. . . = + 00 (resiilt) 

40000. . . = - 00 (result) 

17770. . . = +IND (result) 

00000. . . = +0 (restat) 
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Note that in these cases the 48 least significant bits of the result are zeros. Indefinite 
and zero results generated in accordance with Table 3-5 and Appendix C are always pos- 
itive, but the sign of infinite results is determined by the usual algebraic sign conven- 
tion. For example: 



(+0)/(-0) 


= +IND 


= 17770.. 


. 


(+N)*(-0) 


= +0 


= 00000.. 


. 


(-«')/(-0) 


= +00 


= 37770. . 


.0 


(+°°)/(-o) 


= - 00 


= 40000. . 


.0 



There is no special treatment of zero operands in the Floating Add unit. Zero coeffi- 
cients and the forms OOOOX. . . X and 7777X. . . X are not specially detected, and unstand- 
ardized zero results can be produced. (See description of 30 instruction, page 3-3 7.) 

Overflow and Underflow 

Exponents lying outside the range -17772 ^° ^^'^'^'''q cannot be generated during execution 
of a floating point arithmetic instruction or during execution of a Normalize instruction. 
An attempt to generate an exponent greater than +1777„ yields an infinite result (overflow 
case). An attempt to generate an exponent less than -1777_ yields a zero result (under- 
flow case). All cases of overflow and underflow are listed in Table 3-6, 



Converting Integers to Floating For mat 

Conversion of integers to floating point format makes use of the Shift Unit and the zero 
constant in increment register BO. The BO quantity provides for generation of exponent 
bias in this case. For example, the instructions: 

• Sum of Bj and Bk to Xi (where i = 2, j = 3, k = 4) 

• Pack Xi from Xk and Bj (where i = 2, j = 0, k = 2) 

form an 18-bit signed integer in operand register X2 as a result of the addition of the 
contents of increment registers B3 and B4. The integer coefficient with its sign, plus 
the octal 2000 exponent is then packed into the floating format shown earlier. The coef- 
ficient is not normalized; normalizing may be accomplished with a Normalize instruction. 
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TABLE 3-6. 


OVERFLOW AND UNDERFLOW CONDITIONS 




OVERFLOW 


INSTRUCTIONS 


OVERFLOW CONDITION 


RESULT 


Normalize (24, 25) 


None 







Upper Sum (30, 31, 34, 35) 


None (see Note 1) 







Lower Sum (32, 33) 


None 







Upper Product (40, 41) 


*nl + n2 + eOg > 20008 




Xi = 3777 08 or 

4000 08 


Lower Product (42) 


ni + n2 > 2000g 




(True Sign) 




Quotient (44, 45) 


ni - n2 - 578 ^ 2000g 








UNDERFLOW 


INSTRUCTIONS 


UNDERFLOW CONDITION 


RESULT 


Normalize (24 only) 


Initial coefficient = ±0 


Xi = 0000 08, 

60o 


(Bj) = 


Normalize (24, 25) 


Final Exponent < -20008 S 


o 

Xi = 0000 08, (Ba) are 

correct, (See Note 2.1 


Upper Sum (30, 31, 34, 35) 


None 







Lower Sum (32, 33) 


Final Exponent < -20008 


Xi = 0000 Og 




Upper Product (40, 41) 


ni + n2 + 578 < -2000g 








Lower Product (42) 


n^ + n2 - 1 < -2000g 


> 


Xi = 0000 Og 




Quotient (44, 45) 


n;i - n2 - eOg < - 2000g 


' 







*ni and n2 are the initial exponents. 

Note 1. Overflow of Upper Sum: Overflow cannot occur unless one operand is infinite. 
In this case the result is as indicated. If a one-place Right Shift occurs when 
the larger operand exponent is equal to +17768, a correct result with exponent 
+17778 is generated. 

Note 2. Underflow of Exponent During Normalization: The final (Bj) are the same as if 
underflow had not occurred. In particular, if the initial coefficient is zero, (Bj) 
are equal to 608- 
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Fixed Point Arithmetic 

Fixed point addition and subtraction of 60- bit numbers are handled in the Long Add _ 
Unit (66 00/6700). Negative numbers are represented in one's complement notation, | 
and overflows are ignored. The sign bit is in the high- order bit position (bit 59) and 
the binary point is at the right of the low- order bit position (bit 0). 

The Increment Units provide an 18- bit fixed point add and subtract facility. Negative 
numbers are represented in one's complement notation and overflows are ignored. 
The sign bit is in the high- order bit position (bit 17), and the binary point is at the 
right of the low-order bit position (bit 0). The Increment Units allow program index- 
ing through the full range of Central Memory addresses. 

Fixed point integer addition and subtraction are possible in the Floating Add Unit 
providing the exponents of both operands are zero and no overflow occurs. The unit 
performs the one's complement addition (or subtraction) in the upper half of a 9 8- bit 
accumulator. If overflow occurs, the unit shifts the result one place right and adds one 
to the exponent, thereby producing a floating point quantity. Thus, care must be used 
in performing fixed point arithmetic in the Floating Add Unit. 

Fixed point integer multiplication is handled in the multiply functional units as a subset 
operation of the unrounded Floating Multiply (40, 42) instructions. The multiply is 
double precision (96 bits) and allows separate recovery of upper and lower products. 
The multiply requires that both of the integer operands be converted (by program) to 
floating format to provide biased exponents. This insures that results are not sensed 
as under- flow conditions. The bias is removed when the result is unpacked. 



An integer divide takes several steps and makes use of the Divide and Shift Units. For 
example, an integer quotient XI = X2/X3 is produced by the following steps: 



Instructions 

1) Pack X2 from X2 and BO 

2) Pack X3 from X3 and BO 

3) Normalize X3 in XO and BO 

4) Floating quotient of X2 and XO to XI 

5) Unpack XI to XI and B7 

6 ) Shift XI nominally left B7 places 



Remarks 

Pack X2 

Pack X3 

Normalize X3 (divisor) 

Divide 

Unpack quotient 

Shift to integer position 
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The divide requires that: 

47 
1) both integer (2 maximum) operands be in floating format 

and 2) the divisor be shifted 48 places left 

or 3) The quotient be shifted 48 places right 

or 4) any combination of n left-shifts of the divisor and 48-n right shifts of the 

quotient be accomplished. 

The Normalize X3 instruction shifts the divisor n places left (n > 0), providing divisor 
exponent of -n. The quotient exponent then is: - (-n) - 48 = n - 48 _< 0. 

After unpacking and shifting nominally left, the negative (or zero) value in B7 shifts 
the quotient 48-n places right, producing an integer quotient in XI. A remainder may 
be obtained by an integer multiply of XI and X3 and subtracting the result from X2. 

Description of Central Processor Instructions 

Instruction grouping follows a somewhat pedagogical approach (i. e. , simple to complex) 
and does not necessarily relate instructions to the functional units (6600/6700 system) 
which execute them. Central Processor instructions as related to functional units 
are tabulated in Appendix B, histruction Execution Times. 



TABLE 3-7. CENTRAL PROCESSOR INSTRUCTION DESIGNATORS 



Designator 


Use 


A 


Specifies one of eight 18-bit address registers. 


B 


Specifies one of eight 18-bit index registers; BO is fixed and 
equal to zero. 


fm 


A 6-bit instruction code. 


i 


A 3-bit code specifying one of eight designated registers 
(e.g., Ai). 


J 


A 3-bit code specifying one of eight designated registers 
(e.g., Bj). 


Jk 


A 6- bit constant, indicating the number of shifts to be taken. 


k 


A 3-bit code specifying one of eight designated registers 
(e.g., Bk). 


K 


An 18- bit constant, used as an operand or as a branch 
destination (address). 


X 


Specifies one of eight 60-bit operand registers. 
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Preceding the description of each instruction is the octal code, mnemonic code and 
address field, the instruction name and length. Mnemonic codes and address field 
mnemonics are from COMPASS. The equivalent ASCENT mnemonics are given in 
Appendix D. 

EXAMPLE: 



Octal 
Code 



,BXi, 



Mnemonic 
Code 



.X]+Xk, .Logical Sum of X] and Xk to Xi. .(15 Bits), 

— v — ' ^ v ' ^ V ' 

Address Instruction 
Field Instruction Name Length 



Instruction formats are also given; parallel lines within a format indicate these bits 
are not used in the operation. 



Program Stop and No Operation 



00 



PS 



Program Stop 



(30 Bits) 



" Y//////////////////////A 



29 



24 23 



This instruction stops the Central Processor at the current step in the program. An 
exchange Jump is necessary to restart the Central Processor. 



46 



NO 



No operation (Pass) 



(15 Bits) 



Y//////////////A 



14 



9 8 



This instruction is a "do-nothing" instruction that is typically used to pad the program 
between certain program steps. 
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EXAMPLE : 



P+ I 





59 













p 


30-BIT INST, 


15- 


BIT INST. 


PASS 


1 


30-BIT INST. 




30-BIT 


INST. 





In this example, a Pass instruction is used to pad the remainder of the word 
at P. Since the next instruction is 30 bits, it cannot fit in P and must be placed 
in P + 1 . 



Increment 






50 SAi 


Aj + K 


Set Ai to Aj + K 


51 SAi 


Bj + K 


Set Ai to Bj + K 


52 SAi 


Xj + K 


Set Ai to Xj + K 



(30 Bits) 
(30 Bits) 
(30 Bits) 



fm 


i 


J 


K 



29 



24 23 21 20 18 17 



53 


SAi 


Xj + Bk 


Set Ai to Xj + Bk 


54 


SAi 


Aj + Bk 


Set Ai to Aj + Bk 


55 


SAi 


Aj-Bk 


Set Ai to Aj - Bk 


56 


SAi 


Bj + Bk 


Set Ai to Bj + Bk 


57 


SAi 


Bj-Bk 


Set Ai to Bj - Bk 



(15 Bits) 
(15 Bits) 
(15 Bits) 
(15 Bits) 
(15 Bits) 



fm 


i 


i 


k 
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These instructions perform one's complement addition and subtraction of 18- bit operands 
and store an 18-bit result in address register i. Overflow, in itself, is ignored, but 
an address range fault may result from overflow in this set of instructions. 

Operands are obtained from address (A), increment (B), and operand (X) registers as 
well as the instruction itself (K = 18-bit signed constant). Operands obtained from an 
Xj operand register are the truncated lower 18 bits of the 60-bit word. 

Note that an immediate memory reference is performed to the address specified by 
the final content of address registers Al - A7. The operand read from menaory address 
specified by Al - A5 is sent to the corresponding operand register XI - X5. When A6 
or A7 is referenced, the operand from the corresponding X6 or X7 operand register 
is stored at the address specified by A6 or A7. 



NOTE 

If, in this category of instructions, the result placed 
in address register Ai is an address out of range, the 
following occurs: (Note that this action is independent 
of an Exit selection on Address Out of Range. ) 

If i = 1-5: Operand register Xi is loaded with the 
contents of absolute address zero and the contents of 
memory location (Ai) are unchanged. 

If i = 6 or 7: Operand register Xi retains its original 
contents and the contents of memory location (Ai) 
are unchanged. 

EXAMPLE : 



50 



SAi = Aj + K 



SA, 



Ag + K 



SA^ = 032100g + 234567^ 



SA, 



266667, 



Initial Quantities: 



K 
A. 



234567 
321110c 



A„ = 032100, 
fa t 



X, 



00 



00, 



storage location 26666 7 = 7 

Final Quantities: 

A, = 266667 
4 S 

A„ = 032100„ 
fa 8 

X^ = 7 . . . 75342104600g 



. 75342104600, 
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60 


SBi 


Aj + K 


Set Bi to Aj + K 


61 


SBi 


Bj + K 


Set Bi to Bj + K 


62 


SBi 


Xj + K 


Set Bi to Xj + K 



(30 Bits) 
(30 Bits) 
(30 Bits) 



fm 


i 


i 


K 



29 



24 23 21 20 18 17 



63 


SBi 


Xj + Bk 


Set Bi to Xj + Bk 


64 


SBi 


Aj + Bk 


Set Bi to Aj + Bk 


65 


SBi 


Aj-Bk 


Set Bi to Aj - Bk 


66 


SBi 


Bj + Bk 


Set Bi to Bj + Bk 


67 


SBi 


Bj-Bk 


Set Bi to Bj - Bk 



(15 Bits) 
(15 Bits) 
(15 Bits) 
(15 Bits) 
(15 Bits) 



fm 


i 


i 


k 



14 



These instructions perform one's complement addition and subtraction of 18-bit 
operands and store an 18-bit result in increment register Bi. An overflow condition 
is ignored. 

Operands are obtained from address (A), increment (B), and operand (X) registers as 
well as the instruction itself (K = 18-bit signed constant). Operands obtained from an 
Xj operand register are the truncated lower 18 bits of the 6 0- bit word. 



70 


SXi 


Aj + K 


Set Xi to Aj + K 


71 


SXi 


Bj + K 


Set Xi to Bj + K 


72 


SXi 


Xj + K 


SetXitoXj + K 



(30 Bits) 
(30 Bits) 
(30 Bits) 



fm 


i 


J 


K 



29 



24 23 21 20 18 17 



Rev K 



3-26 



73 


SXi 


Xj + Bk 


Set Xi to Xj + Bk 


74 


SXi 


Aj + Bk 


Set Xi to Aj + Bk 


75 


SXi 


Aj-Bk 


Set Xi to Aj - Bk 


76 


SXi 


Bj + Bk 


Set Xi to Bj + Bk 


77 


SXi 


Bj - Bk 


Set Xi to Bj - Bk 



(15 Bits) 
(15 Bits) 
(15 Bits) 
(15 Bits) 
(15 Bits) 



fm 


i 


J 


k 



14 



These instructions perform one's complement addition and subtraction of 18-bit 
operands and store an 18- bit result into the lower 18 bits of operand register Xi. The 
sign of the result is extended to the upper 42 bits of operand register Xi. An overflow 
condition is ignored. 

Operands are obtained from address (A), increment (B), and operand (X) registers 
as well as the instruction itself (K = 18-bit signed constant). Operands obtained from 
an X] operand register are thr truncated lower 18 bits of the 60-bit word. 



EXAMPT ,F, 




Initial Quantities: 


73 


SXi 


Xj+Bk i = 2 Xg = . . . 0745321402 




SXg 


Xg + B^ j = 3, k = 1 Xg = . . . 0652224310 




SX^ = 


0... 0652224310_ + 511245„ B, = 511245 

o o 1 




SX^- 


7 . .. 7777735555„ 
o 

Final Quantities: 

Xg = "7 . .. 7777735555 

X = . . . 0652224310 

B, = 511245 
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Fixed Point Arithmetic 



36 



IXi Xj + Xk 



Integer sum ofXj and Xk to Xi 



(15 Bits) 



fm 


1 


i 


k 



14 



9 8 6 5 3 2 



This instruction forms a 60-bit one's complement sum of the quantities from operand 
registers Xj and Xk and stores the result in operand register Xi. An overflow condition 
is ignored. 



37 



IXi Xj-Xk 



Integer difference ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


i 


k 



14 



9 8 6 5 



3 2 



This instruction forms the 60-bit one's complement difference of the quantities from 
operand registers Xj (minuend) and Xk (subtrahend) and stores the result in operand 
register Xi. An overflow condition is ignored. 



47 



CXi 



Xk 



Count the number of'l's" in Xk to Xi 



(15 Bits) 



>" I i r/zx^^r^ 



14 



9 8 



6 5 3 2 



This instruction counts the number of "I's" in operand register Xk and stores the count 
in the lower order 6 bits of operand register Xi. Bits 6 through 59 are cleared to zero. 



Rev. A 



3-28 



EXAMPLE: 

47 CXi Xk 1=4 



CX^ X^ k = 1 



CX 



4 = 11, 



Logical 

10 BXi 



Xj 



Transmit Xj to Xi 



Initial Quantities: 

X^ = ... 0543321g 



X^ = 23420. . . 0005547j 



Final Quantities: 

X^ = ... 0543321g 



X^ = ... OOOOOllg 



(15 Bits) 



fm 


i 


J 


y////. 



14 



9 8 6 5 3 3 



This instruction transfers a 60-bit word from operand register Xj to operand register 
Xi. 



11 



BXi Xj * Xk 



Logical Product ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 



9 8 



6 5 



3 2 



This instruction forms the logical product (AND function) of 60-bit words from operand 
registers Xj and Xk and places the product in operand register Xi. Bits of register Xi 
are set to "l" when the corresponding bits of the Xj and Xk registers are "l" as in the 
following example: 

Xj = 0101 
Xk = 1100 

Xi = 0100 
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12 



BXi 



Xj + Xk 



Logical sum ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 



This instruction forms the logical sum (inclusive OR) of 60-bit words from operand reg- 
isters Xj and Xk and places the stim in operand register Xi. Bits of register Xi are set 
to "l" if the corresponding bit ofthe XjorXk register is a "l"as in the following example: 

Xj = 0101 
Xk = 1100 

Xi = 1101 



13 



BXi 



Xj-Xk 



Logical difference ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 9865320 

This instruction forms the logical difference (exclusive OR) of 60-bit words from operand 
registers Xj and Xk and places the difference in operand register Xi. Bits of register Xi 
are set to "l" if the corresponding bits in the Xj and Xk registers are unlike as in the 
following example: 

Xj = 0101 
Xk= 1100 



Xi = 1001 



14 



BXi 



-Xk 



Transmit the complement ofXk to Xi 



(15 Bits) 



'JL ' y//y/\ > 



9 



6 5 



3 2 
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This instruction extracts the 60-bit word from operand register Xk, complements it, and 
transmits this complemented quantity to operand register Xi. 



15 



BXi 



-Xk * Xj 



Logical product ofXj and complement ofXk to Xi (15 Bits) 



fm 


i 


i 


k 



14 



This instruction forms the logical product (AND function) of the 60-bit quantity from op- 
erand register Xj and the complement of the 60-bit quantity from operand register Xk, 
and places the result in operand register Xi. Thus, bits of Xi are set to "l" when the 
corresponding bits of the Xj register and the complement of the Xk register are "l" as in 
the following example: 



Xj = 0101 
Complemented Xk= 0011 

Xj = 0001 



16 



BXi 



-Xk + Xj 



Logical sum. ofXj and complement ofXk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 



This instruction forms the logical sum (inclusive OR) of the 60-bit quantity from operand 
register Xj and the complement of the 60-bit word from operand register Xk, and places 
the result in operand register Xi. Thus, bits of Xi are set to "l" if the corresponding 
bit of the Xj register or complement of the Xk register is a "l" as in the following exam- 
ple: 

Xj = 0101 
Complemented Xk = 0011 



Xi = 0111 
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17 



BXi -Xk-Xj 



Logical difference ofXj and complement ofXk to Xi (15 Bits) 



fm 


i 


J 


k 



14 



9 8 



6 5 



3 2 



This instruction forms the logical difference (exclusive OR) of the quantity from operand 
register Xj and the complement of the 60-bit word from operand register Xk, and places 
the result in operand register Xi. Thus, bits of Xi are set to "l" if the corresponding 
bits of register Xj and the complement of registerXk are unlike as in the following exam- 
ple: 

Xj = 0101 
Complemented Xk = 0011 



Xi = 0110 



Shift 
20 



LXi 



jk 



Left shift Xi, jk places 



(15 Bits) 



fm 


i 


jk 



14 



9 8 6 5 



This instruction shifts the 60-bit word in operand register Xi left circular jk places. Bits 
shifted off the left end of operand register Xi replace those from the right end. 

The 6-bit shift count jk allows a complete circular shift of register Xi. 



21 



AXi jk 



Arithmetic right shift Xi, jk places 



(15 Bits) 



fm 


i 


jk 



14 



9 8 6 5 
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This instruction shifts the 60-bit word in operand register Xi right jk places. The right- 
most bits of Xi are discarded and the sign bit is extended. 



22 



LXi 



Bj Xk 



Left shift Xk notninaUy Bj places to Xi 



(15 Bits) 



fm 


i 


i 


k 



14 



This instruction shifts the 60-bit quantity from operand register Xk the number of places 
specified by the quantity in increment register Bj and places the result in operand regis- 
ter Xi. 

1) If Bj is positive (i. e. , bit 17 of Bj = 0), the quantity from Xk is shifted left- 
circular. (The low order six bits of Bj specify the shift count. ) 

2) If Bj is negative (i. e., bit 17 of Bj = 1), the quantity from Xk is shifted right 
(end off with sign extention). (The one's complement of the low order eleven 
bits of Bj specify the shift count. ) E any of bits 2^-2-^°, after complementing, 
are "I's", the shift is not performed and the result register Xi is cleared to 
all zeros. 



23 



AXi Bj Xk 



Arithmetic right shift Xk nominally Bj places to Xi (15 Bits) 



fm 


i 


J 


k 



14 



9 8 6 5 3 2 



This instruction shifts the 60-bit quantity from operand register Xk the number of places 
specified by the quantity in increment register Bj and places the result in operand regis- 
ter Xi. 



1) If Bj is positive (i. e. , bit 1 7 of Bj = 0), the quantity from register Xk 



IS 
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shifted right (end-off with sign extension). (The low order eleven bits of Bj 



10 



specify the shift count. ) If any of bits 2"-2"" are "I's", the shift is not 
performed and the. result register Xi is cleared to all zeros. 

2) If Bj is negative (i.e., bit 17 of Bj = 1), the quantity from register Xk is shifted 
left circular. (The complement of the lower order six bits of Bj specify the 
shift count. ) 



24 



NXi 



Bj Xk 



Normalize Xk in Xi and Bj 



(15 Bits) 



fm 


i 


i 


k 



This instruction normalizes the floating point quantity from operand register Xk and 
places it in operand register Xi. The number of left shifts necessary to normalize the 
quantity is entered in increment register Bj. A Normalize operation may cause under- 
flow which will clear Xi to all zeros regardless of the original sign of Xk. Normalizing 
either a plus or minus zero coefficient sets the shift count (Bj) to 48^ ^ and clears Xi to 
all zeros. 



If Xk contains an infinite quantity (3777X. . . X or 4000X. . . X) or an indefinite quantity 
(1777X. . . X or 6000X. . . X), no shift takes place. The contents of Xk are copied into Xi 
and Bj is set equal to zero. Optional error exits do occur. 



25 



ZXi Bj Xk 



Round and normalize Xk in Xi and Bj 



(15 Bits) 



fm 


i 


J 


k 



14 



9 8 6 5 3 2 



This instruction performs the same operation as instruction 24 except that the quantity 
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froni operand register Xk is rounded before it is normalized. Rounding is accomplished 
by placing a "1" round bit immediately to the right of the least significant coefficient bit. 
Normalizing a zero coefficient places the round bit in bit 47 and reduces the exponent 
by 48. Note that the same rules apply for underflow. 

If Xk contains an infinite quantity (3777X. . . X or 4000X. . . X) or an Indefinite quantity 
(1777X. . . X or 6000X. . . X), no shift takes place. The contents of Xk are copied into Xi 
and Bj is set equal to zero. Optional error exits do occur. 



26 



UXi 



Bj Xk 



Unpack Xk to Xi and Bj 



(15 Bits) 



fm 


i 


J 


k 



14 



This instruction unpacks the floating point quantity from operand register Xk and sends 
the 48 -bit coefficient to operand register Xiand the 11-bit exponent to increment register 
Bj. The exponent bias is removed during Unpack so that the quantity in Bj is the true 
one's complement representation of the exponent. 

The exponent and coefficient are sent to the low-order bits of the respective registers as 
shown below: 



SIGN BIASED EXPONENT 



PACKED QUANTITY 



UNBIASED 
EXPONENT 



UNPACKED B 



EXPONENT SIGN 
EXTENDED 



m 



17 



10 9 



COEFFICIENT 



1 


1 1 


48 


59 58 




48 47 









\ 


' 








V 



COEFFICIENT 
SIGN EXTENDED 



{^ 



59 



m 



48 47 
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PXi 



Bj Xk 



Pack Xifrom Xk and Bj 



(15 Bits) 



fm 


i 


J 


k 



14 



This instruction packs a floating point number in operand register Xi. The coefficient of 
the number is obtained from operand register Xk and the exponent from increment regis- 
ter Bj. Bias is added to the exponent during the Pack operation. The instruction does 
not normalize the coefficient. 

Exponent and coefficient are obtained from the proper low-order bits of the respective 
registers and packed as shown in the illustration for the Unpack (26) instruction. Thus, 
bits 48 to 58 of Xk and bits 11 to 17 of Bj are ignored. There is no test for overflow or 
underflow. 

Note that if Xk is positive, the packed exponent occupying positions 48 to 58 of Xi is ob- 
tained from bits to 10 of Bj by complementing bit 10; if Xk is negative, bit 10 is not com- 
plemented but bits to 9 are. 



43 



MXi 



jk 



Form mask in Xi, jk bits 



(15 Bits) 



fm 


i 


jk 



14 



9 8 6 5 



This instruction forms a mask in operand register Xi. The 6 -bit quantity jk defines the 
number of "I's" in the mask as counted from the highest order bit in Xi. 

The contents of operand register i = when jk = 0. 
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Floating Point Arithmetic 

30 FXi Xj + Xk Floating sum of Xj and Xk to Xi 



(15 Bits) 



fm 



J 



3 



14 



9 8 6 5 3 2 



This instruction forms the sum of the floating point quantities from operand registers 
Xj and Xk and packs the result in operand register Xi. The packed result is the upper 
half of a double precision sum. 

At the start both arguments are unpacked, and the coefficient of the argument with the 
smaller exponent is entered into the upper half of a 9 8 -bit accumulator. The coefficient 
is shifted right by the difference of the exponents. The other coefficient is then added 
into the upper half of the accumulator. If overflow occurs, the sum is right-shifted one 
place and the exponent of the result increased by one. The upper half of the accumulator 
holds the coefficient of the sum, which is not necessarily in normalized form. The ex- 
ponent and upper coefficient are then repacked in operand register Xi. 

If both exponents are zero* and no overflow occurs, the instruction effects an ordinary 
integer addition. For treatment of special operands and/or indefinite forms, refer to 
Table 3-5 and Appendix C. 



31 



FXi 



Xj~Xk 



Floating difference Xj and Xk to Xi 



(15 Bits) 



fm 


i 


i 


k 



14 9865320 

This instruction forms the difference of the floating point quantities from operand reg- 
isters Xj and Xk and packs the result in operand register Xi. Alignment and overflow 
operations are similar to the Floating Sum (30) instruction, and the difference is not 
necessarily normalized. The packed result is the upper half of a double precision differ- 
ence. 

An ordinary integer subtraction is performed when the exponents are zero. For treat- 
ment of special operands and /or indefinite forms, refer to Table 3-5 and Appendix C, 



^A zero exponent is 2000 



8" 
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32 



DXi 



Xj + Xk 



Floating DP sum ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


i 


k 



14 



This instruction forms the sum oftwo floating point numbers as in the Floating Sum (30) 
instruction, but packs thelowerhalf of the double precision sum with an exponent 48 less 
than the upper sum. For treatment of special operands and/or indefinite forms, refer 
to Table 3-5 and Appendix C, 



33 



DXi Xj - Xk Floating DP difference ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 



This instruction forms the difference of two floating point numbers as in the Floating 
Difference (31) instruction, but packs the lower half of the double precision difference 
with an exponent of 48 less than the upper sum. For treatment of special operands and/ 
or indefinite forms, refer to Table 3-5 and Appendix C. 



34 



RXi 



Xj + Xk 



Round floating sum ofXj and Xk to Xi 



(15 Bits) 



14 



fm 



~1 
I 



This instruction forms the round sum of the floatingpoint quantities from operand regis- 
ters Xj andXk and packs the upper sum of the double precision result in operand regis - 
ter Xi. The sum is formed in the same manner as the Floating Sum instruction but the 
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operands are rounded before the addition, as shown below, to produce a round sum. 

1) A round bit is attached at the right end of both operands if: 

a) both operands are normalized, or 

b) the operands have unlike signs. 

2 ) A round bit is attached at the right end of the operand with the larger exponent 
for all other cases. 

3) In the event that the operands have equal exponents, a round bit is attached to 
the coefficient for only one of the operands. 

For treatment of special operands and/or indefinite forms, refer to Table 3-5 and 
Appendix C. 



35 



KXi 



Xj~Xk 



Round floating difference ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 



This instruction forms the round difference of the floating point quantities from operand 
registers Xj and Xk and packs the upper difference of the double precision result in 
operand register Xi. The difference is formed in the same manner as the Floating 
Difference (31) instruction but the operands are rounded before the subtraction, as 
shown below, to produce a round difference. 

1) A round bit is attached at the right end of both operands if: 

a) both operands are normalized, or 

b) the operands have like signs. 

2) A round bit is attached at the right end of the operand with the larger exponent 
for all other cases. 

3) In the event that the operands have equal exponents, a round bit is attached to I 
the coefficient for only one of the operands. I 

For treatment of special operands and/or indefinite forms, refer to Table 3-5 and 
Appendix C. 
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40 



FXi 



Xj * Xk 



Floating product ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 



This instruction multiplies two floating point quantities obtained from operand registers 
X] (multiplier) and Xk (multiplicand) and packs the upper product result in operand 
register Xi. 

The two 48 -bit coefficients are multiplied together to form a 96-bit product. The upper 
48 bits of the product (bits 48-95) are then packed together with the resulting exponent. 
Note that when using unnormalized quantities, the entire result could lie in the lower- 
order 48 bits of the product; hence, this result would be lost when packing occurs. 

The result is a normalized quantity only when both operands are normalizedjthe exponent 
in this case is the sum of the exponents plus 47 (or 48). 

The result is unnormalized when either or both operands are unnormalized; the exponent 
in this caseisthe sum of the exponents plus 48. Fortreatment of special operands and/ 
or indefinite forms, refer to Table 3-5 and Appendix C. 



41 



BXi 



Xj * Xk 



Round floating product ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 



This instruction multiplies the floating point number from operand register Xk (multi- 
plicand), by the floating point number from operand register Xj, The. upper product re- 
sult is packed in operand register Xi. (No lower product available.) The multiply oper- 
ation is identical to that of instruction 40 with the following exception: 
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Before the left shift of the final product and during the merge operation to form the 

46 
final product, a "l" bit is added to bit 2 . The following rounded result is the net 

effect of this action: 

95 

• for products > 2 , round is by one- fourth 

• for all other products, round is by one- half 

• when one or both operands are unnormalized, round is by one-fourth. 

The result is a normalized quantity only when both operands are normalized; the 
exponent in this case is the sum of the exponents plus 47 (or 48). 

The result is unnormalized when either or both operands are unnormalized; the 
exponent in this case is the sum of the exponents plus 48. For treatment of special 
operands and/or indefinite forms, refer to Table 3-5 and Appendix C. 



42 



DXi 



Xj * Xk 



Floating DP product ofXj and Xk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 



This instruction multiplies two floating point quantities obtained from operand 
registers Xj and Xk and packs the lower product in operand register Xi. The two 
48-bit coefficients are multiplied together to form a 96-bit product. The lower-order 
48 bits of this product (bits 47-00) are then packed together with the resulting exponent. 
The result is not necessarily a normalized quantity. The exponent of this result is 
48 less than the exponent resulting from a 40 instruction using the same operands. 
For treatment of special operands and/or indefinite forms, refer to Table 3-5 and 
Appendix C. 



44 



FXi 



Xj I Xk 



Floating divide Xj by Xk to Xi 



(15 Bits) 



fm 


i 


J 


k 



14 
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This instruction divides two normalized floating point quantities obtained from operand 
registers Xj (dividend) and Xk (divisor) and packs the quotient in operand register Xi. 

The exponent of the result in a no- overflow case is the difference of the dividend and 
divisor exponents minus 48. 

A one-bit overflow is compensated for by adjusting the exponent and right shifting 
the quotient one place. In this case the exponent is the difference of the dividend and 
divisor exponents minus 47. 

The result is a normalized quantity when both the dividend and the divisor are normal- 
I ized. A divide fault occurs when the coefficient of the dividend is two or more times 
as large as the coefficient of the divisor. This forces an indefinite result (17770. . . 0). 
To avoid this, normalize both operands before executing this instruction. For treat- 
ment of special operands and/or indefinite forms, refer to Table 3-5 and Appendix C. 



45 



BXi 



Xj I Xk 



Round floating divide Xj by Xk to Xi 



(15 Bits) 



fm 


i 


i 


k 



14 



This instruction divides the floating quantity from operand register j (dividend) by 
the floating point quantity from operand register Xk (divisor) and packs the round 
quotient in operand register Xi. Rounding is accomplished by adding one-third during 
the division process. In effect, the quantity "2525. . . . 2525„" resides immediately to 
the right of the dividend binary point prior to starting the divide operation. On the 
first iteration, a "1" is added to the least significant bit of the dividend. After each 
iteration (subtraction of divisor from partial dividend) a two- place left shift occurs 
and a "l" is again added to the least significant bit of the partial dividend. Thus, 
successive iterations gradually bring in the one-third round "quantity" (25. . . . 25„). 
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The result exponent in a no-overflow case is the difference of the dividend and divisor 
exponents minus 48. 

A one -bit overflow is compensated for by adjusting the exponent and right shifting the 
quotient one place; in this case the exponent is the difference of the dividend and divisor 
exponents minus 47. 

The result is a normalized quantity when both the dividend and the divisor are normal- 
ized. A divide fault occurs when the coefficient of the dividend is two or more times 
as large as the coefficient of the divisor. This forces an indefinite result (17770. . . 0). 
To avoid this, normalize both operands before executing this instruction. For 
treatment of special operands and/or indefinite forms, refer to Table 3-5 and 
Appendix C. 



Branch 
010 RJ 



K 



Return jump to K 



(30 Rits) 



fm 


m 


K 



29 



21 20 18 17 



The instruction stores an 04 unconditional jump and the current address plus one [(P) + 
l] in the upper half of address K, then branches to K + 1 for the next instruction. Note 
that this instruction is always out of the instruction stack, thus voiding the stack. 

The octal word at K after the instruction appears as follows: 



UNCONDITIONAL 
JUMP 



4 



59 







V 

Bi = Bj 



P+l 

_7\ 



xxxxxx 



000 



30 29 



7/1^ 



A jump to address Kat the end of the branch routine returns the program tothe original 
sequence. 
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02 



JP 



Bi + K 



Jump to Bi +K 



(30 Bits) 



^^ \ -^ Y/A ^ I 



29 



24 23 21 20 18 17 



This instruction adds the contents of increment register Bi to K and branches to the 
address specified by the siim. The branch address is K when i = 0. Addition is per- 

1 R 
formed modulo 2 -1. 

Note that this instruction is always out of the instruction stack, thus voiding the stack. 
For anunindexed, unconditional jiimp, the 04 instruction with i = j = is a better choice. 
Thus, if this instruction is contained in a tight loop, the instruction at K can be obtained 
from the stack, if possible. 



030 


ZR 


Xj 


K 


031 


NZ 


Xj 


K 


032 


PL 


Xi 


K 


033 


NG 


Xi 


K 


034 


IR 


Xj 


K 


035 


OR 


Xj 


K 


036 


DF 


Xj 


K 


037 


ID 


Xj 


K 



Jump to K ifXj — 
Jum,p to K ifXj ¥" 
Jump to K ifXj = plus (positive) 
Jump to K ifXj = negative 
Jump to K ifXj is in range 
Jump to K ifXj is out of range 
Jump to K ifXj is definite 
Jump to K ifXj is indefinite 



(30 Bits) 
(30 Bits) 
(30 Bits) 
(30 Bits) 
(30 Bits) 
(30 Bits) 
(30 Bits) 
(30 Bits) 



fmi 


J 


K 



29 



21 20 18 17 



These instructions branch to K when the 60 -bit word in operand register X. meets the 
condition specifiedby thei digit. The instruction allows zero, sign, and indefinite forms 
tests for fixed or floating point words. 
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The following applies to tests made in this instruction group: 

a) The 03 (ZR) and 031 (NZ) operations test the full 60-bit word in Xj. The 
words 000. . . 000 and 777. . . 777 are treated as zero. All other words are 
non-zero. 



b) 



The 032 (PL) and 033 (NG) operations examine only the sign bit (2^^) of Xj. If 
the sign bit is zero, the word is positive; if the sign bit is one, the word is 
negative. Thus, the sign test is valid for fixed point words or for coefficier 
in floating point words. 

c) The 034 (IR) and 035 (OR) operations examine the upper-order 12 bits of Xj. 
Both plus and minus infinity are detected: 

3777XX. . . XX and 4000XX. . . XX are out of range; all other words 
are in range. 

d) The 036 (DF) and 037 (ID) operations examine the upper-order 12 bits of Xj. 
Both plus and minus indefinite forms are detected: 

1777XX. . . XX and 6000XX. . . XX are indefinite; all other words are 
definite. 



04 


EQ 


Bi Bj K 


05 


NE 


Bi Bj K 


06 


GE 


Bi Bj K 


07 


LT 


Bi Bj K 



Jump to K if Bi = Bj 
Jump to K if Bi :/= Bj 
Jump to KifBi > Bj 
Jump to K if Bi < Bj 



(30 Bits) 
(30 Bits) 
(30 Bits) 
(30 Bits) 



fm 


i 


J 


K 



29 



24 23 21 20 18 17 



These instructions test an 18-bit word from register Bi against an 18-bitword from reg- 
ister Bj (both words signed quantities) for the condition specified and branch to address 
K on a successful test. All tests against zero (all zeros) can be made by setting Bj = BO. 
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The following rules apply in the tests made by these instructions: 

a) Positive zero is recognized as unequal to negative zero, and 

b) Positive zero is recognized as greater than negative zero, and 

c) A positive number is recognized as greater than a negative number. 

Note that the 06 and 07 instructions first perform a sign test on Bi and Bj and the 
Branch/No Branch determination is based on the above rules. If Bi and Bj are of the 
same sign, a subtract test is performed (in the Increment Unit) and the sign of the 
result (Bi-Bj) determines whether a Branch is made. 



Extended Core Storage Communication 

This category of instructions provides the ability to communicate with Extended Core 
Storage (ECS). This section briefly describes Extended Core Storage itself, and a 
full description of the instructions is to be found in the Extended Core Storage 
Reference Manual. 

These instructions must be located in the upper order position of the instruction word. 
If they are not, any attempt at execution will cause an exit to RAp-jwr regardless of the 
error mode bits. This will also happen if the instructions are used in a system that 
does not have ECS. 



on 



BE 



Bj + K 



Bead Extended Core Storage 



(30 Bits) 



fmi 


i 


K 



59 



51 50 48 47 



30 



This instruction initiates a Read operation to transfer [(Bj) + K] 60-bit words from 
Extended Core Storage to Central Memory. The initial Extended Core Storage address 
is [(XO) + RApp„]; the initial Central Memory address is [(AO) + RAj-jj^]. 
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012 



WE 



Bj + K 



Write Extended Core Storage 



(30 Bits) 



fmi 


J 


K 



59 



51 50 48 47 



30 



This instruction initiates a Write operation to transfer [(Bj) + K] 60-bit words from 
Central Memory to Extended Core Storage. The initial Central Memory address is 
[(AO) + RA„j^]; the initial Extended Core Storage address is [(XO) + RA„„„]. 
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ABSOLUTE 
ADDRESS 



100 



ABSOLUTE 
ADDRESS 



1400 



CENTRAL 
MEMORY 



FL = 5300 
CM 



6200 



6477 



•6700 



•^'^CM+^^CM 



100 



EXTENDED 

CORE 
STORAGE 



26500 




30300 



ECS 



^'V*ECS 



FL^„„= 1600 
ECS 



-"^ECS+^'-ECS 




Figure 3-5. Memory Map (Read ECS Example) 

Address Range Faults : Four address range fault conditions can arise when executing 
the Extended Core Storage Communication instructions: 

« Word count fault 

• Central Memory address out of range 

• Extended Core Storage address out of range 

• Last 6 0- bit word (word 7) in FL—^o is referenced 



3-49 



Rev K 



a) Word Count 

If, in forming the word count [(Bj) + kI, the result is negative, an 
address range fault occurs. If the Address Out of Range bit is set in the 
Exit Mode register, an error stop occurs; if this bit is clear, the Central 
Processor passes to the next instruction word at (P)+l with no data transfe 

b) Central Memory Address 

Central Memory address out of range is checked by comparing FLp^ 
with the sum |(A0) + (Bj) + K 1. FL, must be greater than this sum 
or an address range fault occurs. If the Address Out of Range bit is set 
in the Exit Mode register, an error stop occurs; if this bit is clear, the 
Central Processor passes to the next instruction word at (P)+l withno data 
transfer. 

c) Extended Core Storage Address 

Extended Core Storage address out of range is checked by comparing FL-r-,„o 

(XO) + (Bj) + Kj . In the comparison, FL„pg is a 
24-bit quantity with 36 upper-order bits of sign extended; XO holds 
the 24-bit address quantity with 36 zeros occupying the upper-order bit 
positions. The result of this subtraction should always be negative; 
if positive, an address range fault occurs. If the Address Out of Range 
bit is set in the Exit Mode register, an error stop occurs; if this 
bit is clear, the Central Processor passes to the next instruction word at 
(P)+l withno data transfer. 

d) Word 7 reference in FL^^pn 

If, after formation of the ECS address, the address format specifies a 
reference to word 7 in relative address FL„pq, an address range fault 
occurs. If the Address Out of Range bit is set in the Exit Mode register, 
an error stop occurs; if this bit is clear, the Central Processor passes 
to the next instruction word at (P) + 1 with no data transfer. 

Note that address range checks are made on the entire block of both Extended Core Stor- 
age and Central Memory addresses before the transfer (Read or Write) is begun. If any 
address in the block to be transferred is out of range, either in Central Memory or Ex- 
tended Core Storage, no data is transferred, regardless of whether or not the Address 
Out of Range bit is set in the Exit Mode register. 

Rev. A 3-50 



Error Action : An error exit is an exit to the lower- order 3 Obits of the instruction word 
containing the ECS Read or Write instruction. These 30 bits should always hold a jump 
to an error routine. 

Three error conditions cause an error exit: 

1) Parity error(s) when reading ECS. If a parity error is detected, the 
entire block of data is transferred before the exit is taken. 

2) The ECS bank from/to which data is to be transferred is not available 
because the bank is in Maintenance mode, or the bank has lost power. 
If either of these conditions exists on an attempted Read or Write, an 
immediate error exit is taken. 

3) An attempt to reference a nonexistent address. On an attempted 
Write operation, no data transfer occurs and an immediate error 
exit is taken. If the attempted operation is a Read, and addresses 
are in range, zeros are transferred to Central Memory. This is a 
convenient high-speed method of clearing blocks of Central Memory. 

Exchange Jump During ECS Communication: If an Exchange Jump occurs while an Ex- 
tended Core Storage transfer is in progress, the exchange waits until completion of a 
record. Action is then as follows: 

a) If the record just completed is the last record of the block transfer, and 
the transfer was error-free, the Central Processor exits to (P)+l. The 
Exchange Jump then takes place. 

b) If the record just completed is the last record of the block transfer, and 
an error condition exists, the Central Processor exits to the lower in- 
struction, executes it, and the Exchange Jump is performed. 

c) If the record just completed does not complete the block transfer, the 
Exchange Jump occurs, and (P) are stored in the Exchange Jump package. 
A return Exchange Jump to this program begins execution with the ECS 
Read or Write instruction and restarts the transfer. Note the transfer 
does not resume at the point it was truncated; rather, the entire transfer 
must be repeated. 
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4. PERIPHERAL AND CONTROL PROCESSORS 



ORGANIZATION 

The ten Peripheral and Control Processors are identical and operate independently 
and simultaneously as stored-program computers. Thus ten programs maybe running 
at one time. A combination of processors can be involved in one problem, the solution 
of which may require a variety of I/O tasks plus use of Central Memory and Central 
Processor(s). Figure 4-1 shows data flow between I/O devices, the processors, and 
Central Memory. 

The Peripheral and Control Processors act as system control computers and I/O 
processors. This permits the Central Processor to continue high-speed computations 
while the Peripheral and Control Processors do the slower I/O and supervisory 
operations. 



'^ — ij ZMD CP 16S00/6700) 
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a CONTROL 
PROCESSORS 






CENTRAL 
MEMORY 

131,072 
60-BIT 
WORDS 






12 

I/O 

CHANNELS 






EACH 
PERIPHERAL 
a CONTROL 
PROCESSOR 
HAS A 4096 




t 




PERIPHERAL 
EQUIPMENT 




MEM 


ORY 







DISK FILES 
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PERIPHERAL 
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PRINTERS 



Figure 4-1, Flow Chart: 6400/6500/6600/6700 Systems 
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Each processor has a 12-bit, 4096 word random- access memory (not a part of Central 
Memory) with a cycle time of 1000 ns (m.ajor cycle). Execution time of processor 
instructions is based on memory cycle time. A minor cycle is 1/ 10 of a major cycle 
and is another basic time interval. 

All processors communicate with external equipment and each other on 12 independent, 
I bidirectional I/O channels. All channels are 12-bit (plus control) and each maybe 
connected to one or more external devices. Only one external equipment can com- 
municate on one channel at one time, but all 12 channels can be active at one time. 
Data is transferred into or out of the system in 12-bit words; each channel has a 
single register which holds the data word being transferred in or out. Each channel 
operates at a maximum rate of one word per major cycle. 

Data flows between a processor memory and the external device in blocks of words 
(a block may be as small as one word). A single word may be transferred between 
an external device and the A register of a processor. 

The I/O instructions direct all activity with external equipment. These instructions 
determine the status of and select an equipment on any channel and transfer data to 
or from the selected device. Two channel conditions are made available to all 
processors as an aid to orderly use of channels. 

• Each channel has an active /inactive flag to signal that it has been selected 
for use and is busy with an external device. 

• Each channel has a full/ empty flag to signal that a word (function or data) is 
available in the register associated with the channel. 

I Either state of both flags can be sensed. In general, an I/O operation involves the 
following steps: 

1) Determine channel inactive 

2) Determine equipment ready 

3) Select equipment 

4) Activate channel 

5) Input /Output data 

6) Disconnect channel 
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One processor may communicate with another over a channel which is selected as 
output by one and input by the other. A common channel can be reserved for inter- 
processor communication and order preserved by determining equipment and channel 
status . 

A real-time clock reading is available on a channel which is separate from the twelve 
I/O channels. The clock period is 4096 major cycles. The clock starts with power 
on and runs continuously and cannot be preset or altered. The clock may be used 
to determine program running time or other functions such as time-of-day, as required. 

Each processor exchanges data with Central Memory in blocks of n words. Five 
successive 12-bit processor words are assembled into a 60-bit word and sent to 
Central Memory. Conversely, a 60-bit Central Memory word is disassembled into 
five 12-bit words and sent to successive locations in a processor memory. Separate 
assembly (write) and disassembly (read) paths to Central Memory are shared by all 
ten processors. Up to four processors may be writing in Central Memory while 
another four are simultaneously reading from Central Memory. 

The processors generally do not solve complex arithmetic and logical problems;usually 
they perform I/O operations for running Central Processor programs and organize pro- 
blem data (operands, addresses, constants, length of program, relative starting ad- 
dress, exit mode), and store it in Central Memory. Then, an Exchange Jump instruc- 
tion starts (or interrupts) the Central Processor and provides it with the starting ad- 
dress of a problem on file in Central Memory. At the next convenient breakpoint, the 
Central Processor exchanges the contents of its A, B, and X registers, program ad- 
dress, relative starting address, length of program. Exit mode and Extended Core Stor- 
age parameters with the same information for the new program. A later Exchange Jump 
may return to complete the interrupted program. 

Programs for the ten processors are written in the conventional manner and are exe- 
cuted in a multiplexing arrangement which uses the principle of time- sharing. Thus, 
the ten programs operate from separate memories, but all share a common facility for 
add/ subtract, I/O, data transfer to/from Central Memory, and other necessary instruc- 
tion control facilities. The multiplex consists of a 10-position barrel, which stores in- 
formation (in parallel) about the current instruction in each of 10 programs, and a com- 
mon instruction control device, or slot (Figure 4-2). The 10 program steps move 
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around the barrel in series, and each step is presented in turn to the slot. A portion 
of or all of the instruction steps are performed in one pass through the slot, and the al- 
tered instruction (or next instruction in a program) is reentered in the barrel for the 
next excursion. One or more trips around the barrel complete execution of an instruc- 
tion. Thus, up to 10 programs are in operation at one time, and each program is acted 
upon once every 1000 ns. 

One cycle of the multiplex is 1000 ns, with 900 ns consumed in the barrel and 100 ns 
(minor cycle) in the slot. Instructions in the barrel are interpreted at critical time 
intervals so that information is available in the slot at the time the instruction is ready 
to enter the slot. Hence, a reference to memory for data is determined ahead of time 
so that the data word is available in the slot when the instruction arrives. Similarly, 
instructions are interpreted before they reach the slot so that control paths in the slot 
are established when the instruction arrives . 

The slot contains two adders as part of the instruction control. One adder is 12 bits, 
and the other is 18 bits. Both adders treat all quantities as one's complement. 

For I/O instructions or communication with Central Memory, one pass through the 
slot transfers one 12-bit word to or from a peripheral memory. Thus, block transfer 
of data requires a number of trips around the barrel. 

The barrel network holds four quantities which pertain to the current instruction in 
each of the programs. The quantities are held in registers which require a total of 
51 bits. (The barrel can be considered as a 51 x 10 shifting matrix which is closed 
by the slot.) The barrel registers are referred to implicitly in the instruction steps 
and are discussed under Registers, page 4-8. 
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Figure 4-2. Peripheral and Control Processors 
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PERIPHERAL PROCESSOR PROGRAMMING 
Instruction Formats 

An instruction may have a 12-bit or a 24-bit format. The 12-bit format has a 6-bit 
operation code f and a 6-bit operand or operand address d. 



OPERATION 

CODE 

f 



OPERAND OR 

OPERAND ADDRESS 

d 



6 6 



The 24-bit format uses the 12-bit quantity m/ which is the contents of the next program, 
address (P + 1), with d to form, an 18-bit operand or operand address. 





OPERATION 

CODE 

f 








OPERAND OR OPERAND ADDRESS 






1 


d 


m 


^ 


6 


6 


12 


II 
\ 








II 
/\ 




/ 






(i 








V 
( P+l) 





Address Modes 

Program indexing is accomplished and operands manipulated in several modes. The 
two instruction formats provide for 6-bit or 18-bit operands and 6-bit, 12-bit or 18- 
bit addresses. 

No Address 

In this mode d or dm is taken directly as an operand. This mode eliminates the need 
for storing many constants in storage. The d quantity is considered as a 12-bit num- 
ber the upper six bits of which are zero. The dm quantity has d as the upper six bits 
and m as the lower 12 bits. 
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Direct Address 

In thismode.dor m + (d) is used as the address of the operand. The d quantity specifies 
one of the first 64 addresses in memory (0000-0077„). The m + (d) quantity generates 
a 12-bit address for referencing all possible peripheral memory locations {0000-7777„). 
If d / 0, the content of address d is added to m. to produce an operand address (indexed 
addressing). If d = 0, m is taken as the operand address. 



EXAMPLE: A.ddress Modes 

Given : d = 25 
m = 100 

contents of location 25 = 0150 
contents of location 150 = 7776 
contents of location 250 = 1234 



Then: 



MODE 
No Address 



INSTRUCTION 

LDN d 
LDC dm 



Direct Address LDD (d) 

LDM (m + (d)) 

Indirect Address LDI ( (d) ) 



A REGISTER 

000025 
250100 



000150 
001234 

007776 



Indirect Address 

In this mode, d specifies an address the content of which is the address of the desired 
operand. Thus, d specifies the operand address indirectly. Indirect addressing and in- 
dexed addressing require an additional memory reference over direct addressing. 

The Description of Instructions section, page 4-9, uses the expression (d)to define the 
contents of memory location d. An expression with double parentheses ( (d) ) refers to 
indirect addressing. The expression (m + (d)) refers to direct addressing when d = 
and to indexed direct addressing when d ?^ 0. Table 4-1 summarizes the addressing 
modes used for the various Peripheral and Control Processor instructions. 
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TABLE 4-1. ADDRESSING MODES FOR PERIPHERAL 
AND CONTROL PROCESSOR INSTRUCTIONS 



INSTRUCTION 
TYPE 


ADDRESSING MODE 


DIRECT 


INDIRECT 


NO ADDRESS 


Load 


30, 50 


40 


14, 20 


Add 


31, 51 


41 


16, 21 


Subtract 


32, 52 


42 


17 


Logical Difference 


33, 53 


43 


11, 23 


Store 


34, 54 


44 


f£WMW/ 


Replace Add 


35, 55 


45 


W/M/WM 


Replace Add One 


36, 56 


46 


WMMWS 


Replace Subtract One 


37, 57 


47 


WWMWM' 


Long Jump 


01 


W///////// 


YMMWM- 


Return Jump 


02 


W////////// 


///////////////////, 


Unconditional Jump 


W/////M 


W////////// 


03 


Zero Jump 


W/////M 


W/////////A 


04 


Non-Zero Jump 


WMm 


/////////////, 


05 


Positive Jump 


WMS 


WMWM 


06 


Minus Jump 


W/////M 


WMWM 


07 


Shift 


W/////M 


W///////////, 


10 


Logical Product 


'///mm 


w/////////// 


12, 22 


Selective Clear 


w//////// 


w////////// 


13 


Load Complement 


y/y/y/y/yy/// 


///mm. 


15 



Registers 

The four registers in the barrel are A, P, Q, and K. Each plays an important part in 
the execution of processor instructions. 

A Register (18 bits) 

The Arithmetic or A register is an adder. Quantities are treated as positive 
and over flows are not recognized, although an end-aroiond carry does occur. 
No sign extension is provided for 6 -bit or 12 -bit quantities which are entered 
in the low order bits. However, the unused high-order bits are cleared to 
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zero. Zero is represented by all zeros. The A register holds an 18-bit Central Mena- 
ory address during several instructions. A also participates in shift, logical, and some 
I/O instructions. 



P Register (12 bits) 



The Program Address register or P register holds the address of the current instruc- 
tion. At the beginning of each instruction, the contents of P are advanced by one to pro- 
vide the address of the next instruction in the program. If a jump is called for, the 
jump address is entered in P. 



Q Register (12 bits) 

The Q register holds the lower sixbits of a 12 -bit instruction word, or, when the six bits 
specify an address, Q holds the 12-bit word which is read from that address. Q is an 
adder which may add +1 or -1 to its content. 

K Register (9 bits) 



The K register holds the upper six bits (operation code) of an instruction and a 3 -bit trip 
count designator. The trip count is a sequencing scheme to lend control to the sequential 
execution of an instruction. 

There are other registers which provide indirect or transient control during execution 
of instructions. These include registers associated with the I/O channels, the registers 
in the read and write pyramids which assemble successive 12-bit words into 60-bitwords 
or vice versa, and registers which hold the storage address and the word at that address 
for each peripheral memory. 



Description of Peripheral Processor Instructions 

This section describes the Peripheral and Control Processor instructions. Table 4-2 
lists designators used throughout the section. 
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TABLE 4-2. PERIPHERAL AND CONTROL PROCESSOR 
INSTRUCTION DESIGNATORS 



Designator 


Use 


A 


The A register. 


d 


A 6-bit operand or operand address. 


f 


A 6-bit instruction code. 


m 


A 12-bit quantity used with d to form an 18-bit operand 
or operand address. 


P 


The Program Address register. 


Q 


The Q register. 


( ) 


Contents of a register or location 


( ) 


Refers to indirect addressing. 



Preceding the description of each instruction is the octal code, mnemonic code and 
address field, the instruction name and instruction length. Mnemonic codes and 
address field mnemonics are from COMPASS, a Peripheral and Control Processor 
Assembly language. The equivalent ASCENT mnemonics are given in Appendix D. 



EXAMPLE: 



52 



Octal 
Code 



SBM 



Mnemonic 
Code 



md 



Address 
Field 



, Subtrack (m + (d))y 

Instruction 
Name 



(24 Bits), 



Instruction 
Length 



Instruction formats are also given; hashed lines within a format indicate these bits 
are not used in the operation. 
No Operation 



00 


PSN 


24 


PSN 


25 


PSN 



Pass 
Pass 
Pass 



(12 Bits) 
(12 Bits) 
(12 Bits) 



Y/////////y7. 



These instructions specify that no operation be performed. They provide a means of 

padding out a program. 
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Data Transmission 
14 LDN d 



Load d 



(12 Bits) 



f 


d 



6 5 



This instruction clears the A register and loads d. The upper 12 bits of A are zerc 



15 



LCN d 



Load Complement d 



(12 Bits) 



f 


d 



6 5 



This instruction clears the A register and loads the complement of d. The upper 12 bits 
of A are set to one. 



30 



LDD d 



Load (d) 



(12 Bits) 



f 


d 



6 5 



This instruction clears the A register and loads the contents of location d. The upper 
six bits of A are zero. 



34 STD d 



Store (d) 



(12 Bits) 



f 


d 



II 6 5 

This instruction stores the lower 12 bits of A in location d. 



4-11 



Rev. A 



40 



LDI 



d 



Load ((d)) 



(12 Bits) 



f d 



This instruction clears the A register and loads a 12-bit quantity thatis obtained by in- 
direct addressing. The upper six bits of A are zero. Location d is read out of mem- 
ory, and the word obtained is used as the operand address. 



44 



STI 



Store ((d)) 



(12 Bits) 



6 5 



D 



This instruction stores the lower 12 bits of A in the location specified by the contents of 
location d. 



20 



LDC 



dm 



Load dm 



(24 Bits) 



f 


d 


m 



23 



18 17 

— V — 
(P) 



12 II 

_yv_ 



— V — 
(p + n 



This instruction clears the A register and loads an 18-bit quantity consisting of d as 
the higher six bits and m as the lower 12 bits. The contents of the location following 
the present program address are read out to provide m. 



Rev. A 
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50 



LDM 



Load (m + (d)) 



(24 Bits) 



f 


d 


m 



23 



18 17 



V 
(P) 



12 II 



V — 

(P + l' 



This instruction clears the A register and loads a 12 -bit quantity. The upper six bits 
of A are zero. The 12-bit operand is obtained by indexed direct addressing. The 
quantity "m", read out of memory location P + l serves as the base operand address 
to which (d) is added. If d = 0, the operand address is simply m, but if d ?^ 0, then 
m + (d) is the operand address. Thus location d may be used for an index quantity to 
modify operand addresses. 



54 



STM m d 



Store (m + (d)) 



(24 Bits) 



f 


d 


m 



23 18 17 12 II 
\ /\_ 



(P) 



(P + l) 



This instruction stores the lower 12 bits of A in the location determined by indexed ad- 
dressing (see instruction 50). 



Arithmetic 

16 ADN d 



Addd 



(12 Bits) 







II 



6 5 



This instruction adds d (treated as a 6-bit positive quantity) to the content of the A reg- 
ister. 
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17 



SBN 



Subtract d 



(12 Bits) 



f 


d 



6 5 



This instruction subtracts d (treated as a 6-bit positive quantity) from the content of the 
A register. 



31 



ADD 



Add(d) 



(12 Bits) 



f 


d 



6 5 



This instruction adds to the A register the contents of location d (treated as a 12 -bit 
positive quantity). 



32 



SBD 



Subtract (d) 



(12 Bits) 



f 


d 



6 5 



This instruction subtracts from the A register the contents of location d (treated as a 
12-bit positive quantity). 



41 



ADI 



Add ((d)) 



(12 Bits) 



f 


d 



6 5 



This instruction adds to the content of A a 12-bit operand (treated as a positive quantity) 
obtained by indirect addressing. Location d is read out of memory, and the word ob- 
tained is used as the operand address. 
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42 



SBI 



Subtract ((d)) 



(12 Bits) 



f 


d 



This instruction subtracts from the A register a 12 -bit operand (treated as a positive 
quantity) obtained by indirect addressing. Location d is read out of memory, and the 
word obtained is used as the operand address. 



21 



ADC 



dm 



Add dm 



(24 Bits) 



f 


d 


m 


23 

\ 




18 17 




12 
f 


II 
\ 


V 

(P+l) 




/ 






\ 
(F 











This instruction adds to the A register the 18 -bit quantity consisting of d as the higher 
six bits and m as the lower 12 bits. The contents of the location following the present 
program address are read out to provide m. 



51 



ADM 



m 



Add (m + (d)) 



(24 Bits) 



f 


d 


m 



23 



18 17 



(P) 



12 II 



V — 

(P + l) 



This instruction adds to the content of A a 12-bit operand (treated as a positive quantity) 
obtained by indexed direct addressing (see instruction 50). 
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52 



SBM m d 



Subtract (m + (d)) 



(24 Bits) 



f 


d 


m 



23 18 17 12 II 
\ ,, /\_ 



(P) 



(P +1) 



This instruction subtracts from the A register a 12-bit operand (treated as a positive 
quantity) obtained by indexed direct addressing (see instruction 50). 



Shift 
10 



SHN 



Shift d 



(12 Bits) 



f d 



This instruction shifts the contents of A right or left d places. If d is positive (00-37) 
the shift is left circular; if d is negative (40-77) A is shifted right (end off with no sign 
extension). Thus, d = 06 requires a left shift of six places. A right shift of six places 
results when d = 71, 



Logical 

11 LMN 



Logical difference d 



(12 Bits) 



f 


d 



This instruction forms in A the bit -by-bit logical difference of d and the lower six bits 
of A. This is equivalent to complementing individual bits of A that correspond to bits 
of d that are one. The upper 12 bits of A are not altered. 



Rev, A 



4-16 



12 



LPN 



Logical product d 



(12 Bits) 



f 


d 



This instruction forms the bit-by-bit logical product of d and the lower six bits of the A 
register, and leaves this quantity in the lower 6 bits of A. The upper 12 bits of A are 
zero. 



13 



SCN 



Selective clear d 



(12 Bits) 



f 


d 



This instruction clears any of the lower six bits of the A register where there are corres- 
ponding bits of d that are one. The upper 12 bits of A are not altered. 



33 



LMD 



d 



Logical difference (d) 



(12 Bits) 



f d 



This instruction forms in A the bit-by-bit logical difference of the lower 12 bits of A 
and the contents of location d. This is equivalent to complementing individual bits of 
A which correspond to bits of (d) that are one. The upper six bits of A are not altered. 



4-17 
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43 



LMI 



d 



Logical difference ((d)) 



(12 Bits) 



f 


d 



II 6 5 

This instruction forms in A the bit-by-bit logical difference of the lower 12 bits of A 
and the 12-bit operand obtained by indirect addressing. Location d is read out of mem- 
ory, and the word obtained is used as the operand address. The upper six bits of A 
are not altered. 



22 



LPC 



dm 



Logical product dm 



(24 Bits) 



f 


d 


m 


23 

\ 




18 17 
V 




12 II 


V 




/ 






(F 


M 








(P + l) 





This instruction forms in the A register the bit- by-bit logical product of the contents 
of A and the 18-bit quantity dm. The upper six bits of this quantity consist of d and 
the lower 12 bits are the content of the location following the present program address. 



23 



LMC 



dm 



Logical difference dm 



(24 Bits) 



f 


d 


m 


23 


18 17 




12 II 









(I 










V 

(p+n 





This instruction forms in A the bit-by-bit logical difference of the contents of A and 
the 18-bit quantity dm. This is equivalent to complementing individual bits of A which 
correspond to bits of dm that are one. The upper six bits of the quantity consist of d, 
and the lower 12 bits are the content of the location following the present program ad- 
dress. 



Rev. A 



4-lf 



53 



LMM 



m 



d 



Logical difference (m + (d)) 



(24 Bits) 



f 


d 


m 



23 



18 17 



(P) 



12 II 



V — 

(P + l) 



This instruction forms in A the bit-by-bit logical difference of the lower 12 -bits of A 
and a 12-bit operand obtained by indexed direct addressing. The upper six bits of A 
are not altered. 



Replace 

35 RAD 



Replace add (d) 



(12 Bits) 



f 


d 



This instruction adds the quantity in location d to the contents of A and stores the lower 
12 bits of the result at location d. The resultant sum is left in A at the end of the oper- 
ation and the original contents of A are destroyed. 



36 



AOD 



Replace add one (d) 



(12 Bits) 



f 


d 



The quantity in location d is replaced by its original value plus one. The resultant sum 
is left in A at the end of the operation, and the original contents of A are destroyed. 



4-19 



Rev. A 



37 



SOD 



Replace subtract one (d) 



(12 Bits) 



f 


d 



The quantity in location d is replaced by its original value minus one. The resultant 
difference is left in A at the end of the operation, and the original contents of A are 
destroyed. 



45 



RAI 



Replace add ((d)) 



(12 Bits) 



f 


d 



The operand which is obtained from the location specified by the contents of location d, 
is added to the contents of A, and the lower 12 bits of the sum replace the original oper- 
and. The resultant sum is also left in A at the end of the operation. 



46 



AOI 



Replace add one ((d)) 



(12 Bits) 



f 


d 



The operand, which is obtained from the location specified by the contents of location 
d, is replaced by its original value plus one. The resultant sum is also left in A at 
the end of the operation, and the original contents of A are destroyed. 



Rev. A 



4-20 



47 



SOI 



Replace subtract one ((d)) 



(12 Bits) 



f d 



The operand, which is obtained from the location specified by the contents of location 
d, is replaced by its original value minus one. The resultant difference is also left 
in A at the end of the operation, and the original contents of A are destroyed. 



55 



RAM 



m 



Replace add (m + (d)) 



(24 Bits) 



f 


d 


m 



23 

\ 



18 17 



(P) 



12 II 



V 
(P+l) 



The operand, which is obtained from the location determined by indexed direct ad- 
dressing, is added to the contents of A, and the lower 12 bits of the sum replace the 
original operand in memory. The resultant sum is also left in A at the end of the oper- 
ation, and the original contents of A are destroyed. 



56 



AOM 



m 



Replace add one (m + (d)) 



(24 Bits) 



f 


d 


m 


23 




18 17 




12 II 







\ 




V 




/\ 


V 


/ 






(F 


) 








(P + l) 





The operand, which is obtained from the location determined by indexed direct address- 
ing, is replaced by its original value plus one (see instruction 50, page 4-13 for explana- 
tion of addressing). The resultant sum is also left in A at the end of the operation, and 
the original contents of A are destroyed. 
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57 



SOM 



m 



23 



Replace subtract one (m + (d)) 



(24 Bits) 



f 


d 


m 



18 17 



(P) 



12 II 
/\_ 



— v — 
(p+l) 



The operand, which is obtained from the location determined by indexed direct address- 
ing, is replaced by its original value minus one (see instruction 50, page 4-13 for ex- 
planation of addressing). The resultant difference is also left in A at the end of the op- 
eration, and the original contents of A are destroyed. 



Branch 
03 



UJN 



d 



Unconditional jump d 



(12 Bits) 



f 


d 



This instruction provides an unconditional jump to any instruction up to 31 steps forward 
or backward from the current program address. The value of d is added to the current 
program address. If d is positive (01 - 37), then 0001 (+1) - 0037 (+31) is added and the 
jump is forward. If d is negative (40 - 76) then 7740 (-31) - 7776 (-1) is added and the 
jump is backward. The program stops (a Dead Start is necessary to restart the 
machine) when d = 00 or 77. 



04 



ZJN 



d 



Zero jump d 



(12 Bits) 



f 


d 



This instruction provides a conditional jump to any instruction up to 31 steps forward or 
backward from the current program address. If the content of the A register is zero, 
the jump is taken. If the content of A is non-zero, the next instruction is executed. Neg- 
ative zero (777777) is treated as non-zero. For interpretation of d see instruction 03. 



Rev. A 



4-22 



05 



NJN 



Nonzero jump d 



(12 Bits) 



f d 



II 6 5 

This instruction provides a conditional jump to any instruction up to 31 steps forward 
or backward from the current program address. If the content of the A register is 
nonzero, the jump is taken. If A is zero, the next instruction is executed. Negative 
zero (777777) is treated as nonzero. For interpretation of d see instruction 03. 



06 



PJN 



d 



Plus jump d 



(12 Bits) 



f 


d 



This instruction provides a conditional jump to any instruction up to 31 steps forward 
or backward from the current program address. If the content of the A register is 
positive, the jump is taken. If A is negative, the next instruction is executed. Pos- 
itive zero is treated as a positive quantity; negative zero is treated as a negative quan- 
tity. For interpretation of d see instruction 03. 



07 



MJN 



Minus jump d 



(12 Bits) 



f 


d 



This instruction provides a conditional jump to any instruction up to 31 steps forward 
or backward from the current program address. If the content of the A register is 
negative, the jump is taken. If A is positive, the next instruction is executed. Pos- 
itive zero is treated as a positive quantity; negative zero is treated as a negative quan- 
tity. For interpretation of d see instruction 03. 
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01 



LJM 



mi 



Long jump to m + (d) 



(24 Bits) 



f 


d 


m 



23 



18 17 



12 II 



This instruction jumps to the sequence beginning at the address given by m. + (d). If 
d = 0, then m is not modified. 

02 RJM m d Return jump tom + (d) (24 Bits) 



f 


d 


m 


23 




18 17 




12 II 







\ 




V 




/\ 


V 


/ 






(F 


) 








(P + l) 





This instruction jumps to the sequence beginning at the address given by m + (d). U 
d = then m is not modified. The current program address (P) plus two is stored at 
the jump address. The new program commences at the jump address plus one. This 
program should end with a long jump to, or normal sequencing into, the jump address 
minus one, which should in turn contain a long jump, 0100. The latter returns the 
original program address plus two to the P register. 

Central Processor and Central Memory 



260 



EXN 



Exchange jum.p 



(12 Bits) 



f 




^ 





(DUAL CP BIT) 



I O 



This instruction transmits an 18-bit (absolute) address (only 17 bits are used) from 
the A register to the Central Processor with a signal which tells the Central Processor 
to perform an Exchange Jump, with the address in A as the starting location of a file 
of 16 words containing information about the Central Processor program to be executed. 
The 18-bit initial address must be entered in A before this instruction is executed. 
The Central Processor replaces the file with similar inforniation from the interrupted 
Central Processor program. The Peripheral Processor is not interrupted. 

I In 6500/6700 systems with dual Central Processors, the lowest order bit of the instruc- 
tion format specifies which Central Processor the Exchange Jump will interrupt. In 
6400 and 6600 systems, this bit is not interpreted. 



Rev K 
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27 



KPN 



Read program address 



(12 Bits) 



y//////////. 



I 



(DUAL CP BIT) 



This instruction transfers the content of the Central Processor Program Address 
register, P, to the Peripheral Processor A register; this allows the Peripheral 
Processor to determine whether the Central Processor is running. In a 6500/6700 
system with dual Central Processors, the lowest order bit of the instruction format 
specifies which Central Processor P register is to be examined. In 6400 and 6600 
systems, this bit is not interpreted. The largest value that (P) may be is 17 bits. 
The remaining bit (bit 17) will appear set to this instruction when an ECS transfer 
is in progress. However, bit 17 is not set in P. 



m 



CRD 



Central read from (A) to d 



(12 Bits) 



f d 



This instruction transfers a 60- bit word from Central Memory to five consecutive 
locations in the processor memory. The 18-bit address of the Central Memory 
location must be loaded into A prior to executing this instruction. (Note that this is 
an absolute address. ) The 60-bit word is disassembled into five 12-bit words begin- 
ning at the left. Location d receives the first 12-bit word. The remaining 12-bit words 
go to succeeding locations. 



61 



CRM 



m 



d 



Central read (d) words from (A) to m 



(24 Bits) 



f 


d 


m 



23 



18 17 



— v— 

(P) 



12 II 



V — 

(P + l) 



This instruction reads a block of 60- bit words from Central Memory. The content of 
location d gives the block length. The 18-bit address of the first central word must be 
loaded into A prior to executing this instruction. (Note that this is an absolute address. 
During the execution of the instruction, (P) goes to processor address and P holds m. 
Also, (d) goes to the Q register where it is reduced by one as each central word is 
processed. The original content of P is restored at the end of the instruction. 



4-25 



Rev K 



Each central word is disassembled into five 12-bit words beginning with the high-order 
12 bits. The first word is stored at processor memory location m. The content of P 
(which is holding m) is advanced by one to provide the next address in the processor 
memory as each 12 -bit word is stored. If P overflows, operation continues as P is ad- 



vanced from 7777g to 0000^ 
cutive. 



These locations willbe written into as if they were conse- 



The content of A is advanced by one to provide the next Central Memory address after 
each 60-bit word is disassembled and stored. Also, the contents of the Q register are 
reduced by one. The blocktransfer is complete whenQ = 0. The block of Central Mem- 
ory locations goes from address (A) to address (A) + (d) -1. The block of processor 
memory locations goes from address m to na + 5(d) -1. 



62 



CWD 



d 



Central write to (A) from d 



(12 Bits) 



f d 



This instruction assembles five successive 12-bit words into a 60-bit word and stores 
the word in Central Memory. The 18-bit address word designating the Central Memory 
location must be in A prior to execution of the instruction. (Note that this is an absolute 
address. ) 

Location d holds the first word to be read out of the processor memory. This word 
appears as the higher order 12 bits of the 60-bit word to be stored in Central Memory. 
The remaining words are taken from successive addresses. 



Hev. F 



4-26 



63 



CWM 



mi 



Central write (d) words to (A) from m 



(24 Bits) 



f 


d 


m 



23 



IB 17 



12 II 



This instruction assembles a block of 60-bit words and writes them in Central Memory. 
The content of location d gives the number of 60-bit words. The content of the A reg- 
ister gives the beginning Central Memory address. (Note that this is an absolute ad- 
dress.) During the execution of this instruction (P) goes to processor address and P 
holds na. Also, (d) goes to the Q register, where it is reduced by one as each central 
word is assembled. The original content of P is restored at the end of the instruction. 

The content of P (the m portion of the instruction) gives the address of the first word 
to be read out of the processor memory. This word appears as the higher order 12 bits 
of the first 60 -bit word to be stored in Central Memory. 

The content of P is advanced by one to provide the next address in the processor memory 
as each 12 -bit word is read. If P overflows, operation continues as P is advanced from 
7777g to OOOOg. These locations will be read from as if they were consecutive. 

The content of A is advanced by one to provide the next Central Memory address after 
each 60-bit word is assembled. Also, Q is reduced by one. The block transfer is com- 
plete when Q = 0. 



Input/Output 
64 AJM 



Jump to m if channel d active 



(24 Bits) 



f 


d 


m 



23 



18 17 



— v— 

(P) 



12 II 



V — 

(P+l) 



This instruction provides a conditional jump to a new program sequence beginning at an 
address given by the contents of m. The jump is taken if the channel specified by d is 
active. The current program sequence continues if the channel is inactive. 
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65 



IJM 



md 



Jump to m if channel d inactive 



(24 Bits) 



f 


d 


m 



23 



18 17 



(P) 



12 II 
/\_ 



V — 

(P+l) 



This instruction provides a conditional jump to a new program sequence beginning at 
an address given by m. The jump is taken if the channel specified by dis inactive. The 
current program sequence continues if the channel is active. 



66 



FJM 



mi 



Jump to m if channel dfull 



(24 Bits) 



f 


d 


m 


23 




18 17 




12 II 







\ 




V 




/\ 


V 


/ 






(F 


') 








(P + i) 





This instruction provides a conditional jump to a new program sequence beginning at an 
address given by m. The jump is taken if the channel designated by d is full. The pres- 
ent program sequence continues if the channel is empty. 

An input channel is full when the input equipment has placed a word on the channel and 
that word has not yet been sampled by a processor. The channel is empty when a word 
has been accepted. An output channel is full when a processor places a word on the 
channel. The channel is empty when the output equipment has sampled the word. 



67 



EJM 



mi 



Jump to m if channel d empty 



(24 Bits) 



f 


d 


m 


23 




18 17 




12 II 






/ 






\ 
(F 










V 
(P + l) 





This instruction provides a conditional jump to a new program sequence beginning at an 
address specified by m. The jump is taken if the channel specified by d is empty. The 
current program sequence continues if the channel is full. (See instruction 66 for ex- 
planation of full and empty. ) 
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70 



IAN 



Input to A from channel d 



(12 Bits) 



f 


d 



11 6 5 

This instruction transfers a word from input channel d to the lower 12 bits of the A 
register. The upper 6 bits of the A register are cleared to zeros. 

NOTE 

This instruction will hang up the Peripheral Processor 
if executed when the channel is inactive. 



71 



lAM 



mi 



Input (A) words to mfrom channel d 



(24 Bits) 



f 


d 


m 



23 

\ 



18 17 



(P) 



J\_ 



V — 

(P+l) 



This instruction transfers a block of 12- bit words from input channel d to the processor 
memory. The content of A gives the block length. The first word goes to the processor] 
address specified by m. The content of A is reduced by one as each word is read. The 
input operation is complete when A = or the data channel becomes inactive. If the 
operation is terminated by the channel becoming inactive, the next location in the 
processor memory is set to all zeroes. However, the word count is not affected by 
this empty word. Therefore, the contents of the A register gives the block length 
minus the number of real data words actually read in. 

During this instruction address 0000 temporarily holds P, while m is held in the P 
register. The content of P advances by one to give the address for the next word as 
each word is stored. 

NOTE 

If this instruction is executed when the data channel is 
inactive, no input operation is accomplished and the 
program continues at P + 2. However, the location 
specified by m is set to all zeroes. 
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72 



OAN d 



Output from A on channel d 



(12 Bits) 



f d 



11^ 



6 5 



This instruction transfers a word from A (lower 12 bits) to output channel d. 

NOTE 

This instruction will hang up the Peripheral 
Processor if executed when the channel is 
inactive. 



73 



OAM 



mi 



Output (A) words from m on channel d 



(24 Bits) 



f 


d 


m 



23 



18 17 



— v— 

(P) 



12 



_/\_ 



V — 

(P+1) 



This instruction transfers a block of words from the processor memory to channel d.. The 
first word comes from the address specified by m. The content of A specifies the num- 
ber of words to be sent out. The content of Ais reduced by one as eachword is readout. 
The output operation is complete when A = or the channel becomes inactive. 

During this instruction address 0000 temporarily holds P, while m is held in the P reg- 
ister. The content of P advances by one to give the address of the next word as each 
word is taken frona memory. 



NOTE 

If this instruction is executed when the data 
channel is inactive, no output operation is 
accomplished and the program continues at 
P+ 2. 



Rev. F 
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74 ACN d Activate channel d (12 Bits) 



n 6 5 

This instruction activates the channel specified by d. Activating a channel (must pre- 
cede a 70 - 73 instruction) alerts and prepares the I/O equipment for the exchange of 
data. 

NOTE 

Activating an already active channel causes the 
Peripheral Processor to hang up. 

7^ T^CISI d Disconnect channel d (12 Bits) 



f 


d 



This instruction deactivates the channel specified by d. As a result, the I/O equipment 
stops and the buffer terminates. 

NOTE 

1 ) Do not deactivate an already inactive channel or 
the Peripheral Processor will hang up. 

2) If an output instruction is followed by a disconnect I 
instruction without first establishing that the infor- 
mation has been accepted by the input device | 
(check for channel empty) the last word trans- 
mitted may be lost. 

3) Do not deactivate a channel before putting a useful 
program in the associated processor. Processors 
other than are hung up on an Input instruction 

(71). Deactivating a channel after Dead Start causes I 

an exit to the address specified by the contents of 
location 0000 plus 1 and execution of that program. 
If the channel is deactivated without a valid program 
in that processor, the processor will execute what 
ever program was left in memory; it could, there- 
fore, run wild. 
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Function (A) on channel d 
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The external function code in the lower 12 bits of A is sent out on channel d, 

NOTE 

Do not execute this instruction when the 
channel is Active or the Peripheral Processor 
will hang up. 
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Function m on channel d 



(24 Bits) 
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The external function code specified by m is sent out on channel d. 

Access to Central Memory 

The Peripheral and Control Processors have access to all Central Memory storage lo- 
cations. Four of the instructions (60, 61, 62, 63 - described previously) transfer one 
word or a block of words from a peripheral naemory to Central Memory or vice versa 
Data from an external equipment is read into a peripheral memory and, with separate 
instructions, transferred frona there to Central Memory where it may be used by the 
Central Processor. Conversely, data is transferred from Central Memory to a peri- 
pheral memory and then transferred by separate instructions to external equipment. 
Note that all addresses sent to Central Memory from Peripheral and Control Proces- 
sors are absolute addresses, rather than relative addresses. 

Read Central Memory 

The 60 and 61 instructions read one word or a block of 60-bit Central Memory words. 
The Central Memory words are delivered to a five stage read pyramid where they are 
disassembled into five 12-bit words, beginning with the high-order word. Successive 
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stages of the pyramid contain 60, 48, 36, 24 and 12 bits. The upper 12 bits of the 
word are removed and sent to a peripheral memory as the word is transferred through 
each stage. Thus, a 60-bit word is disassembled into five 12-bit words. 

Words naove through the pyramid when the stage ahead is clear. One pass through the 
slot determines that the next stage is clear, sends 12 bits of the word to a peripheral 
memory, and moves the word ahead to the cleared stage. The pyramid is a part of the 
slot and may be time shared by up to four processors. Thus four Central Memory 
words may be in the pyramid at one time in varying stages of disassembly. With a 
full pyramid. Read instructions from other processors are partially executed (house- 
keeping) and circulated unchanged in the barrel until the number of pyramid users 
drop below four. Waiting processors are serviced in the order in which they appear 
at the slot, * Other instruction control provides address incrementing and keeps the 
word count. 

The Central Memory starting address must be entered in A before a Read instruction 
is executed. A Load dm (20) instruction may be used for this. For a one word transfer, 
the d portion of the Read (60) instruction specifies the following: 

d = peripheral address (0000-0077 ) of first 12-bit word; remaining words 

o 

go to d + 1, d + 2, etc. 

For a block transfer, d and m of the read (61) instruction specify the following: 

(d) = number of Central Memory words to be transferred; reduced by one 
for each word transferred. 

m = peripheral starting address; increased by one to provide locations for 
successive words. (A) is increased by one to locate consecutive Central 
Memory words. 

Write Central Memory 

The 62 and 63 instructions assemble 12-bit peripheral words into 60-bit words and 
write them in Central Memory. Peripheral words are assembled in a write pyramid 
and delivered from there to Central Memory. As in Read Central Memory, the pyramid 
is a part of the slot and is time- shared by up to four processors. Write pyramid 
action is similar to Read pyramid action except for the assembly. 



*Refer to Central Memory Access Priority (Appendix F) for exceptions. I 
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The starting address in Central Memory is entered in A before the Write instruction 
is executed. For a one word transfer, the d portion of the Write (62) instruction 
specifies the following: 

d = peripheral address (0000-0077 ) of first 12-bit word; remaining words 
are taken from d + 1, d + 2, etc. 

For block transfer, d and m of the Write (63) instruction specify the following: 

(d) = number of Central Memory words to be transferred; reduced by one 
for each word transferred. 

m = peripheral starting address; increased by one to locate each successive 
peripheral word. (A) is increased by one to provide consecutive Central 
Memory locations. 

Access to the Central Processor 



The Peripheral and Control Processors use two instructions to communicate with the 
Central Processor. One instruction starts a program running in the Central Processor 
and the other instruction raonitors the progress of the program. 

Exchange Jump 

The 260 instruction (described previously) starts a program running in the Central 
Processor or interrupts a current program and starts a new program running. In 
either case, the Central Processor is directed to a Central Memory file of 16 words 
which stores information about the new program to be executed (see Exchange Jump 
section). The 18-bit starting address of this file m.ust be entered in A before the Ex- 
change Jump instruction is executed. The Central Processor replaces the file with 
similar but current information from the interrupted program. A later Exchange Jump 
instruction referencing this file returns the interrupted program to the Central Pro- 
cessor for completion. This exchange feature permits the Peripheral Processor to 
time- share the Central Processor, 
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Read Program Address 

The 2 7 instruction (described previously) transfers the content of the Central Processor 
P register into a peripheral A register. The peripheral program tests the A register 
content to determine the condition of the Central Processor. 1£ A i" 0, the Central Pro- 
cessor is running a program, may have come to a normal (instruction) stop, or may 
have stopped due to an out-of-bounds error (unselected). (Refer to Exit Mode section, 
page 3-11.) If A = 0, the Central Processor has stopped due to a selected Exit mode 
error; the reference address for the Central Processor program is then examined to 
determine which error condition exists. A Stop instruction (00 ) in the upper six bits of 
the reference address signals a stop; the next lower six bits define the nature of the exit 
(see Exchange Jump section, page 3-9). 

Input and Output 

There are 12 instructions to direct activity on the I/O channels. These instructions se- 
lect a unit of external equipment and transfer data to or from the equipment. The instruc- 
tions also determine whether a channel or external equipment is available and ready to 
transfer data. The preparatory steps insure that the data transfer is carried out in an 
orderly fashion. 

Each external equipment has a set of external function codes which are usedby the pro- 
cessors to establish modes of operation and to start or stop data transfer. Also, the 
devices are capable of detecting certain errors (e.g., parity error) and provide an in- 
dication of these errors to the controlling processor. The external error conditions can 
be read into a processor for interpretation and further action. Details of mode selec- 
tion and error flags in external devices such as card readers andmagnetic tape systems 
are presented in the 6000 Series Peripheral Equipment Reference manual. 

Data Channels 

Each channel has a 12-bit bi-directional data register and two control flags which indi- 
cate: 

• The channel is active or inactive 

• The channel register is full or empty 

The 64 and 65 instructions determine the state of the channel, and the 66 and 67 instruc- 
tions determine the state of the register. The flags provide housekeeping information 
for the processors so that channels can be monitored and processed in an orderly way. 
The flags also provide control for the I/O operation. 
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Word Rate: Each processor is serviced by the slot once every major cycle. This sets 
the maximum word rate on a channel at one word each 1000 ns, a 1 megacycle word 
rate. Up to 10 processors can be communicating with I/O equipment over separate 
channels at this rate since each processor is regularly serviced at major cycle intervals. 



Channel Active /inactive Flag: A channel is made active by a Function (76, 77) instruc- 
tion or an Activate Channel (74) instruction. 

The Function instruction selects a mode of operation in the external equipment. The 
instruction places a 12-bit function wordinthe channel register and activates the channel. 
The external equipment accepts the function word, and its response to the processor 
clears the register and drops the channel active flag. The latter action produces the 
channel inactive flag. 



The activate channel instruction prepares a channelfor data transfer . Subsequent input 
or output instructions transfer the data. A disconnect channel instruction after data 
transfer is complete returns the channel to the inactive state. 



Register Full /Empty Flag: A register is full when it contains a function or data word 
for an external equipment or contains a wordreceivedfrom an external equipment. The 
register is empty when it is cleared. The flags are turned on or off as the register 
changes state. 

On data output, the processor places a wordinthe Channel register and sets the full flag. 
The external device accepts the word, clears the register, and sets the empty flag. The 
empty flag and channel active flag signal the processor to send another word to the reg- 
ister to repeat the sequence. 

On input, the external device places a word in the register and sets the full flag. The 
processor stores the word, clears the register, and sets the empty flag. The empty 
flag and channel active flag signal the external device to deliver another word. 
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Data Input 

Several instructions are necessary to transfer data from external equipment into a pro- 
cessor. The instructions prepare the channel and equipment for the transfer and then 
start the transfer. Some external equipment, when once started, send a series of words 
(record) spaced at equal time intervals and then stops automatically between records. 
Magnetic tape equipment is an example of this type of transfer. The processor can read 
all or a part of the record and then disconnect the channel to end the operation. The 
latter step makes the channel inactive. Other equipment, such as the display console, 
can send one word (or character) and then stop. The input instructions allow the input 
transfer to vary from one word to the capacity of the processor. 

An input transfer may be accomplished in the following way: 

1) Determine if the channel is inactive. A Jump to m on channel d 
Inactive (65) instruction does this. Here, m can be a function 
instruction to select Read mode or determine the status of the equipment. 

2) Determine if the equipment is ready. A Function m on Channel d (77) 
instruction followed by an Activate channel d (74) followed by an Input to A 
from Channel d (70) instruction loads A with the status response of the 
desired equipment. Here, m is a status request code, and the status response 
in A can be tested to determine the course of action. 

3) Disconnect Channel d (7 5); this avoids hanging up the processor. 

4) Select Read mode in the equipment. A Function m on Channel d (77) 
instruction or Function (A) on Channel d (76) instruction will send a code 
word to the desired device to prepare it for data transfer. 

5) Enter the number of words to be transferred in A. A Load d (14) or Load 
(d) (30) instruction will accomplish this. 

6) Activate the channel. An Activate Channel d (74) instruction sets the 
channel active flag and prepares for the impending data transfer. 

7) Start input data transfer. An Input (A) Words to m on Channel d (71) 
instruction or an Input to A from Channel d (70) instruction starts data 
transfer. The 71 instruction transfers one word or up to the capacity 
of the processor memory. The 70 instruction transfers one word only. 
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8) Disconnect the channel. A Disconnect Channel d (75) instruction makes 
the channel inactive and stops the flow of input information. 

The design of some external, equipment requires timing considerations in issuing function, 
activate, and input instructions. The timing consideration may be based on motion in the 
equipment, i. e. , the equipment must attain a given speedbefore sending data (e. g. , mag- 
netic tape). In general, timing considerations can be resolved by issuing the necessary 
instructions without an intervening time gap. The external equipment literature lists 
timing considerations to be taken into account. 

Data Output 

The data output operation is similar to data input in that the channel and equipment 
must be ready before the data transfer is started by an output instruction. 

An output transfer may be accomplished in the following way: 

1) Determine if the channel is inactive. A Jump to m on Channel d 
Inactive (65) instruction does this. Here, m can be a function instruction 
to select Write mode or determine the status of the equipment. 

2) Determine if the equipment is ready. A Function m on Channel d (77) 
followed by an Activate channel d (74) followed by an Input to A from Channel 
d (70) instruction loads A with the status response of the desired equipment. 
Here, m is a status request code, and the status response in A can be 
tested to determine the course of action, 

3) Disconnect Channel d (75); this avoids hanging up the processor. 

4) Select Write mode in the equipment. A Function m on Channel d (77) 
instruction or Function (A) on Channel d (76) instruction will send a code 
word to the desired device to prepare it for data transfer. 

5) Enter the number of words to be transferred in A. A Load d (14) or Load d 
(30) instruction will accomplish this. 

6) Activate the channel. An Activate Channel d (74) instruction signals an 
active channel and prepares for the impending data transfer. 

7) Start data transfer. An Output (A) Words from m on Channel d (73) instruction 
or an Output from A on Channel d (72) instruction starts data transfer. The 
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73 instruction can transfer one or more words while the 72 instruction 
transfers only one word, 

8) Test for channel empty. A Junap to m if Channel d Full (66) instruction 
where m = current address, provides this test. The instruction exits to 
itself until the channel is empty. When the channel is enapty, the processor 
goes on to the next instruction which generally disconnects the channel. The 
instruction acts to idle the program briefly to insure successful transfer of 
the last output word to the recording device. 

9) Disconnect the channel. A Disconnect Channel d (75) instruction makes 
the channel inactive. Data flow in this case terminates automatically when 
the correct number of words is sent out. 

Instruction tinaing considerations, as in a data input operation, are a function of the ex- 
ternal device. 

Real-Time Clock 

The real-time clock runs continuously; its period is 4096 cycles (4. 096 ms). The clock 
may be sampled by any Peripheral and Control Processor with aninput to A (70) instruc- 
tion from channel 14g. The clock is advanced by the storage sequence control and can- 
not be cleared or preset. 
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5. SYSTEM INTERRUPT 



INTRODUCTION 

Essentially, detecting and handling interruptible conditions involves both hardware I 
and software. This section describes hardware provisions for detecting and handling 
interrupt. The salient features of an operating system for implementing interrupt 
handling are described in the operating system reference manual. 

HARDWARE PROVISIONS FOR INTERRUPT 
Exchange Jump 

Within a Peripheral Processor, execution of an Exchange Jump instruction initiates 
hardware action in the Central Processor to interrupt the current Central Processor 
program and substitute a program, the parameters of which are defined in the Exchange 
Jump package. Note that the Exchange Jump is also used to start the Central Processor 
from a Stop condition. (Refer to the Exchange Jump section). I 

Channel and Equipment Status 

Within the Peripheral Processors, hardware flags indicate the state of various 
conditions in the data channels, e.g.. Full/ Empty, and Active /Inactive. External 
equipments are capable of detecting certain errors (e. g. , parity error) and hold 
status information reflecting their operating conditions (e. g. , Ready, End of File, etc. ) 
Channel and equipment status information may be examined by instructions in the 
Peripheral Processors. The Input/Output section describes these instructions. For 
detailed status information on external devices such as magnetic tape units and card 
readers, refer to literature associated with these devices. 
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Exit Mode 

Central Processor hardware provides for three types of error halt conditions (Exit mode): 

• Address out of range (i. e. , out of boiinds) 

• Operand out of range (i.e., exponent overflow) 

• Indefinite result 

Detecting the occurrence of one or more of these conditions is acconaplished by the 
hardware and causes an error halt. Note that halting on any of these conditions is 
selectable; selection is performed by setting appropriate flags in the Exit mode portion 
of the Exchange Jump package. (Refer to Exit Mode, page 3-11. ) 
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6. MANUAL CONTROL 



INTRODUCTION 



Manual control operation is provided through 1) the dead start panel and 2) the consolel 
keyboard. The Dead Start circuit is a means of manually entering a 12-word program 
(normally a load routine) to start operation. The console keyboard provides for the 
manual entry of data or instructions under program control. 



DEAD START 

The dead start panel* (Figure 6-1) contains a 12 x 12 matrix of toggle switches, a 
MODE switch to select SWEEP, LOAD, or DUMP, a DEAD START switch, and a 
CEJ/MEJ and a PPU-A switch. =i=* The panel also contains memory margin switches 
which are used for maintenance checks. The three modes of operation (Load, Sweep, 
Dump) selectable via the dead start panel are described below. 

Load Mode 

To initially load programs and data into the computer system, the MODE switch is 
placed in the LOAD position. The matrix of toggle switches is set to a 12-word (or 
less) program (switch up = "l", switch down = "O"). The program set in the switch 
matrix is normally a load routine used to load a larger program from an input device 
such as a disk file or magnetic tape unit. 

The DEAD START switch is turned on momentarily, then off. Turning on the DEAD 
START switch initiates the following operations: 

1) Assigns processors 0-11 to corresponding data channels, 

2) Sends a Master Clear to all I/O channels. A Master Clear removes all 
equipment selections except the dead start panel, and sets all channels to 
the Active and Empty condition (ready for input). 



*See Appendix E for Dead Start operation in 64XX-7, 64XX-8, and 64XX-9 Systems. 
**CEJ/MEJ and PPU-A switches are for 6700 only or those systems which have the 
applicable Standard Options. 
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3) Sets all processors to the Input (71) instruction, 

4) Clears the P register and sets the A register to lOOOOp in all processors. 

5) Transmits a zero word followed by the 12 words from the toggle switches into 
memory locations 0000 - 0014„ of peripheral processor 0, and then disconnects 
data channel causing word OOISq of peripheral processor to be zeroed and 
causing peripheral processor to start execution with the instruction at loca- 
tion 0001. 

After the switch matrix program is read from the dead start panel, the panel is auto- 
matically disconnected. Processor reads location 0000, adds one to its content, and 
begins executing the program at address 0001. The other processors are still set to the 
Input (71) instruction and may receive data from processor via their assigned channels. 

Sweep Mode 

Placing the MODE switch in the SWEEP position and momentarily turning on the DEAD 
START switch results in the following: 

1) Sets all processors to instruction 50X. 

2) Clears all processor P registers to zero. 

The translation of the SOX instruction in each processor causes each processorto sweep 
through its memory, reading and restoring the contents of each location, without execut- 
ing instructions. Sweep mode is a maintenance tool useful in checking the operation of 
memory logic. 

Dump Mode 

Placing the MODE switch in the DUMP position and momentarily turning on the DEAD 
START switch initiates the following operations: 

1) Assigns processors O-Ho to corresponding data channels. 

2) Sends a Master Clear to all I/O channels except channel 0. 

3) Holds channel to Active and Empty. 

4) Sets all processors to the Output (73) instruction. 

5) Clears the P register and sets the A register to lOOOOg in all processors. 
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NOTE 

CEJ/MEJ and PPU-A switches are for 6700 only or 
its equivalent. 
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Figure 6-1. Dead Start Panel 



6-3 



Rev K 



Each of the processors senses the Active and Empty condition of its assigned channel 
and outputs the content of its memory address zero. Each of the I/O channels is then 
set to Full (except channel 0), and the processors wait for an Empty signal. Each 
processor advances its P register by one and reduces the content of its A register by 
one (to 7776„). At this point, the processors waiting for an Empty signal are hung up 
and cannot proceed. 

Channel (assigned to processor 0) is held to Empty by the DUMP position. Processor 
0, therefore, proceeds through the 73 instruction until the contents of A are reduced 
to one. Processor has now dumped its entire memory content on channel (although 
no I/O device was selected to receive it). Execution then starts with the instruction 
at the location specified by the contents of location 0000 plus one; it is now free to 
execute a dump program which must have been previously stored in its memory 
(location 0000 must have been previously set to the starting address minus one). 



CONSOLE 

The display console (Figure 6-2) consists of two cathode ray tube displays and a key- 
board for manual entry of data. A typical System may have several display consoles 
for controlling independent programs simultaneously. 

Keyboard Input 

The console may be selected for input to allow manual entry of data or instructions 
to the computer. The first part of an operating system program may select keyboard 
input to allow the programmer to manually select a routine from the operating system. 
Data entered via the keyboard may be displayed on one of the display tubes if desired. 
Assembly and display of keyboard entries is done by a routine in the operating system. 

Display 

The console may be selected to display (Figure 6-3) in either the Character or Dot mode. 
In the Character mode, two alphanumeric characters may be displayed for each 12-bit 
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word sent from a processor. Character sizes are: 

Small - 64 characters /line 

Medium - 32 characters /line 

Large - 16 characters /line 

In Dot mode, a pattern of dots (graph, figures, etc. ) may be displayed. Each dot is lo- 
cated by two 12 -bit words: a vertical coordinate and a horizontal coordinate. 

A display prograra must repeat a display periodically in order to maintain persistence 
on the display tube. 




Figure 6-2. Display Console 
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Figure 6-3. Sample Display- 
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Appendix A 

AUGMENTED I/O BUFFER AND CONTROL 

(6416) 



CONTROL DATA 6416 
AUGMENTED I/O BUFFER AND CONTROL 

The CONTROL DATA 6416 Augmented I/O Buffer and Control unit is a large-scale, 
solid state device for communication with the Central Processor of 6400, 6500, 6600, 
Eind 6700 Computer Systems. 

DESCRIPTION 

The 6416 is comprised of ten Peripheral and Control Processors and a Central 
Memory. A summary of characteristics for the 6416 is tabulated below. 

PERIPHERAL AND CONTROL PROCESSORS 

• 10 identical processors 

Each processor has a 4096 word magnetic core memory (12-bit) 

Random access, coincident current 

Major cycle = 1000 ns; Minor cycle = 1€0 ns 

• 12 input /output channels 

All channels common to all processors 

Maximum transfer rate per channel - one word/major cycle 

All channels may be active simultaneously 

All channels 12-bit bidirectional 

• Real-time clock (period = 4096 major cycles) 

• Instructions 

Logical 

Branch 

Add/ Subtract 

Input / Output 

Central Memory Access 

Extended Core Storage Access 

• Average instruction execution time = two major cycles 

• Indirect addressing 

• Indexed addressing 
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CENTRAL MEMORY 

• 16, 384 words (60- bit) 

• Memory organized into four logically independent banks of 4096 words with 
corresponding multiphasing of banks 

• Random-accesSj coincident- current, magnetic core 

• One major cycle for read- write 

• Maxinaum memory reference rate to all banks; four addresses /m.ajor cycle 

• Maximum rate of data flow to/from memory; four words /major cycle 

The 6416 has no Central Processor; otherwise, it is identical to the 6400, 6500, 6600, 
and 6700 Computer Systems. The following discussion assumes use of the 6416 in a 
typical 6400, 6600, or 6700 system; the 6416 can also be used in a 6500 system. 
Furthermore, it is a computer capable of operating alone. 



SYSTEMS CONFIGURATIONS 

The 6416, in typical system.s configurations, provides an extremely useful and power- 
ful system expansion. For installations with multiple on-line users, the 6416 provides 
additional data channels facilitating additional external equipments. The ten Peripheral 
and Control Processors, each capable of independently executing programs, and the 
16, 384 word 60-bit Central Memory significantly increase the multiprogramming and 
batch job processing capabilities of the 6400, 6500, 6600^ and 6700 Computer Systems. 

A typical configuration diagrammed in Figure A- 1 illustrates the orientation of a 
6416 with a 6400, 6600, or 6700 Computer System. The 6416 is attached to the 6400, 
6600, or 6700 system via one of the Peripheral Processor Data Channels. 

The 6682/6683 Satellite Coupler accepts and relays control signals and data to provide 
smooth information flow throughout the system. 

In this configuration, the 6416 may be thought of as a batching terminal, where batch 
jobs may enter the system, be assembled, and placed in the 16K distributive memory. 
Access to the 6400 or 6600/6700 Central Processor for job execution is then under 
operating system control. 
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Figure A-1. Typical Configuration: 6416 with 6400 or 6600/6700 System 

Another possible systems configuration (Figure A- 2) incorporates Extended Core 
Storage between the 6400 or 6600/6700 Central Memory and the 6416 16K memory. i 

This configuration implies a hierarchy of memories as follows: 

1) Extended Core Storage as a system Central Memory 

2) 6400 or 6600/6700 Central Memory as a system Central Processor memory i 

3) 6416 16K memory as a distributive memory 



6416 INSTRUCTIONS 

Within the 6416, Peripheral Processor instructions are identical to those of the 6400, 
6500 and 6600/6700 systems with two exceptions. These are the Read Extended Core i 
Coupler Status instruction (27, RCS) and the Extended Core Transfer "instruction (26, 
ECT). The instructions are described in the ECS Reference Manual. 
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Figure A- 2. Typical Configuration with Extended Core Storage 
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Within the Extended Core Coupler, status bit 17 is dynamic; bits 16 and 15 are cleared 
ekch time an Extended Core Storage transfer is initiated. 



26 ECT d 



Extended Core Transfer 



26 


j 



6 5 

n 



OPERATION 
CODE 



(12 bits) 



Execution of the Extended Core Transfer instruction initiates nnemory operations by 
transmitting an 18-bit address, "n", from the Peripheral Processor A register to the 
6416 16K memory. Address "n" holds a word, the format of which is as follows: 



Xn Aq K 



59 



STARTING ADDRESS IN 
EXTENDED CORE STORAGE 



36 35 
^\ 



STARTING ADDRESS IN 
16 K MEMORY 



18 17 
l\ 



WORD COUNT 



The "d" portion of this instruction specifies the storage operation to be performed: 



If j = 0, Read K words from Extended Core Storage into 16K memory. 
If "j" = 1, Write "K" words from 16K memory into Extended Core Storage. 



NOTE 

If this instruction is executed without Extended Core 
Storage in the system configuration, it acts as a Pass 
(Do- Nothing) instruction. 

Note that addresses contained in the word at address "n" are absolute addresses. Oper- 
ating systems may require relocation (adding RA to an address) and Field Length test- 
ing, e.g., is "address +RA'.' > FL? (The Exchange Jump package contains RA and FL 

values for Central Memory and for Extended Core Storage. ) The 6416 has no hardware 
for automatic relocation and Field Length testing; it is therefore incumbent upon the 
program to perform these functions whenever required by an operating system. 



A-5 



Rev, D 



Appendix B 
INSTRUCTION EXECUTION TIMES 



INSTRUCTION EXECUTION TIMES 

The execution times for Central and Peripheral and Control Processor instructions 
are given in the following paragraphs. Factors which influence instruction execution 
time and hence program running time are also given. 

CENTRAL PROCESSOR (6600/6700 SYSTEM) | 

The execution time of Central Processor instructions is given in minor cycles, and 
instructions are grouped under the functional unit (6600/6700) which executes the in- I 
struction. Time is counted from the time the unit has both input operands to when the 
instruction result is available in the specified resiilt register. Central Memory access 
time is not considered in those increment instructions which result in memory 
references to read operands or store results. 

The following paragraphs give some general statements about Central Processor 
instruction execution and summarize the statements into a list which may be used 
as a guide to efficient use of the Central Processor functional units. 

Central Processor programs are written in the conventional manner and are stored 
in Central Memory under direction of a Peripheral and Control Processor. After an 
Exchange Jump start by a Peripheral and Control Processor program. Central 
Processor instructions are sent automatically, and in the original sequence, to the 
instruction stack, which holds up to 32 instructions. 

Instructions are read from the stack one at a time and issued to the functional units 
for execution. A scoreboard reservation system in Central Processor control keeps 
a current log of which units are busy (reserved) and which operating registers are 
reserved for results of computation in functional units. 

Each unit executes several instructions, but only one at a time. Some branch instruc- 
tions require two units, but the second unit receives its direction from the branch unit. 
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The instruction issue rate may vary from a theoretical maximum rate of one instruction 
every minor cycle (sustained issmng at this rate may not be possible because of unit and 
Central Memory conflict) and resulting parallel operation of many units to a slow issue 
rate and serial operation of units. The latter results when successive operations de- 
pend on results of previous steps. Thus, program running time can be decreased by 
efficient use of the many units. Instructions which are not dependent on previous steps 
may be arranged or nested in areas of the program where they may be executed during 
operation time of other units. Effectively, this eliminates dead spots in the program 
and steps up the instruction issue rate. 

The following steps summarize instruction issuing and execution: 

1) An instruction is issued to a functional unit when 

• the specified functional unit is not reserved 

• the specified result register is not reserved for a previous result. 

2) Instructions are issued to functional units at minor cycle intervals when no 
reservation conflicts (see above) are present. 

3) Instruction execution starts in a functional unit when both operands are 
available (execution is delayed when an operand(s) is a result of a previous 
step which is not complete. 

4) No delay occurs between the end of a first unit and the start of a second unit 
which is waiting for the results of the first. 

5) No instructions are issued after a Branch instruction until the Branch 
instruction has been executed. The Branch Unit uses 

• an Increment Unit to form the go to k + Bi and go to k if Bi . . . 
instructions, or 

• the Long Add unit to perform the go to k if Xj . . . instructions 
in the execution of a Branch instruction. The time spent in the Long 
Add or Increment Units is part of the total branch time. 

6) Read Central Memory access time is computed from the end of Increment 
Unit time to the time operand is available in X operand register. Minimum 
time is 500 ns, assuming no Central Memory bank conflict. 

CENTRAL PROCESSOR (6400 AND 6500 SYSTEMS) 
Central Processors in the 6400 and 6500 systems have unified Arithmetic units, rather 
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than separate functional units as in the 6600 system. Instructions in these Central Pro- 
cessors, therefore, are executed in sequential fashion with little concurrency. 

All execution times for instructions listed in Table B-1 include readying the next instruc- 
tion for execution. For the Return Jump instruction and the Jump instructions (in which 
the jump condition is met). Table B-1 lists times which include obtaining the new instruc- 
tion word from storage and readying it for execution. Times listed, then, are complete 
times except for possible additional time due to hardware limitations or memory bank 
conflicts. Factors which may add to the stated times in Table B-1 are summarized be- 
low: 

1) Reading the next instruction word of a program from Central Memory (termed 
an RNI - Read Next Instruction) is in part concurrent with instruction execution. 
The RNI is initiated between execution of the first and second instructions of the 
instruction word being processed. Initiating the RNI operation requires 2 minor 
cycles; the remainder of the RNI time is in time parallel with the execution of 
the remaining instructions in the instruction word. (Refer to Figure B-1.) 



INITIATE 
RNI 




200 NSEC 



-ff- 



EXECUTION OF 

INSTRUCTIONS 

2 AND 3 

RNI 

MINIMUM OF 

800 NSEC 



TOTAL RNI TIME 



-fl- 



-i h 



Figure B-1. RNI Timing Example 

In the example diagrammed in Figure B-1, execution of instruction 2 is de- 
layed 2 minor cycles until RNI initiation is complete. 

In calculating execution times for a program, add 2 minor cycles to each in- 
struction word in a program to cover the RNI initiation time. Exceptions to 
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this rule are the Return Jump and the Jump instructions (in which the jump condition is 
met) when these occupy the upper positionof the instruction word. Since the stated times 
for these instructions in Table B-1 include the time required to read up the new instruc- 
tion word at the jump address, no additional time is required. 

Example : 



JUMP TO K ( MET ) 


PASS 


PASS 



ADD 1 


ADD 2 


LOAD 


STORE 



Instruction 


Time Required 


Jump 


13 Minor Cycles 


Add 1 


5 Minor Cycles 


RNI Initiation 


2 Minor Cycles 


Add 2 


5 Minor Cycles 


Load 


12 Minor Cycles 


Store 


10 Minor Cycles 



Total Time Required = 47 Minor Cycles 

2) After RNI has been initiated (between the first and second instructions of the 
instruction word), a minimum of 8 minor cycles elapse before the next instruc- 
tion word is available for execution. If the total time required by instructions 
in the lower order positions of the word is less than 8 minor cycles, allow a 
minimiim of 8 minor cycles, regardless of the execution times stated in Table 
B-1. 

Example : 



JUMP TO K ( NOT MET) 



PASS 



PASS 



(P)+ I 
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Instruction 

Jump (not met) 
RNI Initiation 
Pass = 3l 6, but RNI 
Pass = 3 J Minimum 



Time Required 

5 Minor Cycles 
2 Minor Cycles 

8 Minor Cycles 



Minimum time before 
instruction word at 
P + 1 is available for 
execution 



15 Minor Cycles 



3) 



The Return Jump instruction, all Jump instructions in which the jump condition 
is met, and Load/Store Memory instructions always require additional time 
when located in the second instruction position of an instruction word. This 
additional time is caused by hardware limitations and is not due to memory 
bank conflicts. 

Additional Time Required 



Instruction 

a) Jumps (02 - 07) in which 
the jump condition is met 

b) Return Jump (010) 

c) Load/Store (5X instructions 
with i ?^ 0) 



If Used As Second Instruction 
in Word 

1 Minor Cycle 

2 Minor Cycles 

2 Minor Cycles 



4) An additional 3 minor cycles due to bank conflict are required if the second in- 
struction of a word references the memory bank in which (P)+l is located. 

5) A Store (not Load) as the first instruction of a word can cause a bank conflict 
with (P) + l. If this occurs, 3 minor cycles are added to the execution time. 

Summary of guidelines for efficient coding in the 6400 and 6500 Central Processors: 

• Always attempt to place Jump instructions in the upper parcel 
of the instruction word. In most cases, this avoids both the 
additional time for RNI (2 minor cycles) and the possibility of a 
memory bank conflict with (P) + 1 . 

• Where possible, place Load/Store instructions in the lower order 
two parcels to avoid lengthening execution times as outlined above. 
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CENTRAL PROCESSOR INSTRUCTION EXECUTION TIMES 

I Central Processor instruction execution times are tabulated in Table B-1 (6500 
times are for each Central Processor). Instructions are tabulated according to the 
functional units in which they are executed; this functional unit designation, of course, 
does not apply to the 6400 and 6500 systems. Their Central Processors have unified 
arithmetic sections. Instruction execution times are listed in minor cycles. 



TABLE B-1. INSTRUCTION EXECUTION TIMES: CENTRAL PROCESSOR 



1 


Octal 




6400 


6600/ 


1 


Code 


BRANCH UNIT 


6500 


6700 




00 


STOP 


_ 


_. 




010 


RETURN JUMP to K 


21 


13 




Oil 


READ EXTENDED CORE STORAGE 


'I* '1- 






012 


WRITE EXTENDED CORE STORAGE 


=:-;- 


** 




02 


GO TO K + Bi t 




13 


14 




030 


GO TO K if Xj = zero 






13 


9* 




031 


GO TO K if Xj 5^ zero 






13 


9* 




032 


GO TO K if X] = positive 






13 


9=!= 




033 


GO TO K if Xj = negative 






13 


9* 




034 


GO TO K if Xj is in range 


" 1t 




13 


9* 




035 


GO TO K if Xj is out of range 




<F^ J, »(^ ^ 

'r- 1- '1- ^ 


13 


9* 




036 


GO TO K if Xj is definite 




' 


13 


9* 




037 


GO TO K if Xj is indefinite ^ 






13 


9* 




04 


GO TO K if Bi = Bj t 




13 


8* 


1 


05 


GO TO K if Bi ?f Bj t 




13 


O -■'' 
O ''" 


06 


GO TO K if Bi > Bj t 




13 


8* 




07 


GO TO K if Bi < Bj t 




13 


8* 






t GO TO K + Bi and GO TO K if Bi 








- - - tests made in Increment Unit 








•f-f GO TO K if Xj tests made in 








Long Add Unit 






=!=Add 6 minor 


cycles to branch time for **Execution times for Extended Core 




a branch to £ 


m instruction which is out Storage operations ar 


e dependent 




of the stack 


(no memory conflict con- upon several factors; 


refer to Ex- 




sidered); adc 


i 2 minor cycles to branch tended Core Storage Reference 




time for a nc 


3 branch condition in the Manual for timing information. 




stack. Add 5 
time for a nc 


minor cycles to branch **..jumps in which the jump condition 
5 branch condition out of ■ x x • r • -i 




the stack. 


IS not met require 5 minor cycles. 
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TABLE B-1. (Cont'd) 



Octal 
Code 


BOOLEAN UNIT 


6400 
6500 


6600/ 
6700 


10 
11 
12 
13 
14 
15 
16 
17 


TRANSMIT Xj to Xi 

LOGICAL PRODUCT of Xj and Xk to Xi 

LOGICAL SUM of Xj and Xk to Xi 

LOGICAL DIFFERENCE of Xj and Xk to Xi 

TRANSMIT Xk COMP. to Xi* 

LOGICAL PRODUCT of Xj and Xk COMP. to Xi 

LOGICAL SUM of Xj and Xk COMP. to Xi 

LOGICAL DIFFERENCE of Xj and Xk COMP. to Xi 


5 
5 
5 
5 
5 
5 
5 
5 


3 
3 
3 
3 
3 
3 
3 
3 


Octal 
Code 


SHIFT UNIT 


6400 
6500 


6600/ 
6700 


20 
21 
22 
23 
24 
25 
26 
27 
43 


SHIFT Xi LEFT jk places 

SHIFT Xi RIGHT jk places 

SHIFT Xk NOMINALLY LEFT Bj places to Xi 

SHIFT Xk NOMINALLY RIGHT Bj places to Xi 

NORMALIZE Xk in Xi and Bj 

ROUND AND NORMALIZE Xk in Xi and Bj 

UNPACK Xk to Xi and Bj 

PACK Xi from Xk and Bj 

FORM jk MASK in Xi 


6 
6 
6 
6 

7 
7 
7 
7 
6 


3 
3 
3 
3 
4 
4 
3 
3 
3 


Octal 
Code 


ADD UNIT 


6400 
6500 


6600/ 
6700 


30 
31 
32 
33 
34 
35 


FLOATING SUM of Xj and Xk to Xi 
FLOATING DIFFERENCE of Xj and Xk to Xi 
FLOATING DP SUM of Xj and Xk to Xi* 
FLOATING DP DIFFERENCE of Xj and Xk to Xi 
ROUND FLOATING SUM of Xj and Xk to Xi 
ROUND FLOATING DIFFERENCE of Xj and Xk to Xi 




4 
4 
4 
4 
4 
4 


Octal 
Code 


LONG ADD UNIT 


6400 
6500 


6600/ 
6700 


36 
37 


INTEGER SUM of Xj and Xk to Xi 
INTEGER DIFFERENCE of Xj and Xk to Xi 


6 

6 


3 
3 


Octal 
Code 


MULTIPLY UNIT** 


6400 
6500 


6600/ 
6700 


40 
41 
42 


FLOATING PRODUCT of Xj and Xk to Xi 
ROUND FLOATING PRODUCT of Xj and Xk to Xi 
FLOATING DP PRODUCT of Xj and Xk to Xi 


57 
57 
57 


10 
10 
10 



*Conip. = Complement; DP = Double Precision 
"'-Duplexed units - instruction goes to free unit 
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TABLE B-1. (Cont'd) 



Octal 
Code 


DIViJJE UNIT 


6400 
6500 


6600/ 
6700 


44 
45 
47 


FLOATING DIVIDE Xj by Xk to Xi 
ROUND FLOATING DIVIDE Xj by Xk to Xi 
SUM of I's in Xk to Xi 


57 
57 
68 


29 

29 

8 






46 


PASS 


3 


1 



Octal 




6400 


6600/ 


Code 


INCREMENT UNIT* 


6500 


6700 


50 


SUM of Aj and K to Ai 


** 


Q T- '1- '1- 


51 


SUM of Bj and K to Ai 


** 


3 


52 


SUM of Xj and K to Ai 


** 


3 


53 


SUM of Xj and Bk to Ai 


'1- 'I* 


3 


54 


SUM of Aj and Bk to Ai 


** 


3 


55 


DIFFERENCE of Aj and Bk to Ai 


-1- '1- 


3 


56 


SUM of Bj and Bk to Ai 


«t-»U 


3 


57 


DIFFERENCE of Bj and Bk to Ai 


** 


3 


60 


SUM of Aj and K to Bi 


5 


3 


61 


SUM of Bj and K to Bi 


5 


3 


62 


SUM of Xj and K to Bi 


5 


3 


63 


SUM of Xj and Bk to Bi 


5 


3 


64 


SUM of Aj and Bk to Bi 


5 


3 


65 


DIFFERENCE of Aj and Bk to Bi 


5 


3 


66 


SUM of Bj and Bk to Bi 


5 


3 


67 


DIFFERENCE of Bj and Bk to Bi 


5 


3 


70 


SUM of Aj and K to Xi 


6 


3 


71 


SUM of Bj and K to Xi 


6 


3 


72 


SUM of Xj and K to Xi 


6 


3 


73 


SUM of Xj and Bk to Xi 


6 


3 


74 


SUM of Aj and Bk to Xi 


6 


3 


75 


DIFFERENCE of Aj and Bk to Xi 


6 


3 


76 


SUM of Bj and Bk to Xi 


6 


3 


77 


DIFFERENCE of Bj and Bk to Xi 


6 


3 



^Duplexed units - instruction goes to free iinit 



-When: i 
i 
i 



the execution time is 6 minor cycles 
1-5 the execution time is 12 minor cycles 
6 or 7 the execution time is 10 minor cycles 



50-57 A register reserved for 3 minor cycles. 



When "i" 



1-5 then Xi register reserved for 8 minor cycles. 
6-7 then Xi register reserved for 9 minor cycles. 
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6600/6700 CENTRAL PROCESSOR TIMING NOTES I 

1. The times given in Table B- 1 are computational times - the time needed 
after the execution start until the result is computed and ready to be stored 
into the result register. 

2. The functional units are not freed until one minor cycle after the result has 
been stored into the result register. 

3. A result register value may be used as an operand to another instruction as 
soon as the result has been stored into the register (same minor cycle). This 
result register will not be freed to be used as a result register of another 
instruction until one cycle after the result has been stored into that register 
(no trunk priority considered). 

4. An instruction is issued to a functional unit if: 

a) The word containing the. instruction is in the stack and the U registers, 

b) The functional unit(s) needed are free, and 

c) The result register (s) needed are free (note Table B-2 and B-3). 

If these three conditions are not met, a first order conflict exists and all I 

further instruction issues are held until they are satisfied. Each issued 
15-bit instruction requires one minor cycle before the next instruction is 
available for issue. Each issued 30-bit instruction requires two minor cycles 
before the next instruction is available for issue. 

5. Execution within a functional unit does not start until the operands are 
available (note Table B-3). The two operands required are fetched from the 
registers at the same time (one operand is not loaded while the unit waits for 
a second operand). 

6. In instructions 02-07, where more than one functional unit is used, the 
instruction is not issued until both functional units involved are free. 

7. Times given for instructions 01-07 and 50-57 do not consider any memory 
conflict conditions. 
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8. In instructions 50-57, if i = 1, 2 . . . 5 (load from memory instructions), the 
Xi register value is not available until 8 minor cycles after the start of the 
instruction execution (assuming no miemory conflicts). When two load instruc- 
tions begin execution one minor cycle apart, one extra minor cycle is required 
for execution of the later instruction. Therefore, the second executed instruc- 
tion would require 9 cycles for the load, 5 cycles for the Increment Unit, and 

4 cycles for the A register. 

9. In instructions 50-57, if i = 6 or 7 (store to memory instructions), the Xi 
register is not available for a result register until 10 minor cycles after the 
instruction begins execution (assuming no memory conflicts). 

10. When executing sequential instructions, the minimum time is one word of 
instructions every 8 cycles for instructions out of stack and every 4 cycles 
for instructions in stack. The time of issue of the last parcel of an instruc- 
tion word to the time of issue of the first parcel of the next instruction word, 
while executing sequential instructions out of stack is 4 cycles, and 1 cycle 
for those in stack. If the last instruction in an instruction word is a 30-bit 
instruction, a minimum of 5 cycles (out of stack) and 2 cycles (in stack) are 
required from the time of issue to a functional unit of this instruction to the 
time of issue at the first instruction in the next word. An instruction word 
is parcelled as illustrated below. 



PARCEL 


PARCEL 1 


PARCEL 2 


PARCEL 3 



59 45 44 30 29 15 14 

11. When a branch out of the stack is taken, 15 minor cycles are normally 
required for a 03ijk instruction and 14 minor cycles are normally required 
for other branch instructions (considering no memory conflict). The latter 
timing is from the start of branch instruction execution to the point when the 
instruction at the branch address is ready for issue to a functional unit. 

12. Nine cycles are required for OSijk instructions when the branch is taken 
within the stack. The next sequential word is recognized as within the stack. 
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13. Eight cycles are required for 04i]k to OVijk instructions when the branch is 
taken within the stack. The next sequential word is recognized as within the 
stack. 

14. Eleven cycles are required for OSijk instructions when the branch is not 
taken (time from branch execution to issue of next instruction) if in the stack 
or if falling through to the same word. Out of the stack fall- through to the 
next word takes 14 cycles. 

15. Ten cycles are required for 04i]k to 07ijk instructions when the branch is 
not taken (time from branch execution to issue of next instruction) if in the 
stack or if falling through to the same word. Out of the stack fall-through to 
the next word takes 13 cycles. 

16. The BO register is handled as any other Bi register for timing purposes 

(i. e. , BO will hold up execution of an instruction if it is a result register of 
a previous noncompleted instruction, etc. ). 

17. Neither Increment Unit may be involved in a load operation if a store 
operation is to be issued, and neither Increment Unit may be involved in a 
store operation if a load operation or a store operation is to be issued. The I 
sequential loading of instruction words does not affect the load/ store conditions 
of the Increment Units. Increments of AO are considered neither loads nor 
stores. 

18. The operand registers are available to more than one functional unit in the 
same minor cycles if the units are in different groups. 

Group 1 Group 2 Group 3 

Boolean Shift Increment 1 

Divide Floating Add Increment 2 

Multiply 1 Long Add 
Multiply 2 

19. The time needed for a functional unit to operate on indefinite, out-of- range, 
or zero values is the same as for normal, in- range values (i. e. , no gain or 
loss in execution time due to a unit recognizing an indefinite operand and 
setting an indefinite result). 
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20. 



21. 
22. 



23. 



An Index Jump instruction (02) will always destroy the stack. If an unconditional 
jump back in the stack is desired, a 0400K instruction may be used (to save 
memory access time for instructions). 

A Return Jump instruction (01) will always destroy the stack. 

After a result has been computed by a functional unit, the result register is 
checked to see if it is still needed as an operand register for a previously 
issued instruction. This is done so that a result will not overlay an operand 
to a previously issued instruction. 

In cases of bank conflict, unaccepted addresses get a chance at access every 
three minor cycles. If the address can then be accessed, the memory opera- 
tion proceeds. If the bank is still busy, the address circulates in the hopper, 
while access is permitted for any other source requesting access. 



TABLE B-2. FUNCTIONAL UNIT DATA TRUNK ASSIGNMENTS AND PRIORITY 



FUNCTIONAL UNIT 


RESULT (i) 


OPERAND (j) 


OPERAND (k) 


Trunk Priority 


Trunk 


Priority 


Trunk Priority 


Group 1 : Shift 

Add 
Long Add 


3 (X)^ 1 

4 (B)/ * 

3 2 
3 3 


1 

1 

1 


2 

1 
3 


2 2 

2 1 
2 3 


Group 2: Boolean 
Divide 
Multiply 1 
Multiply 2 


7 1 
7 2 
7 3 

7 4 


5 
5 
5 
5 


4 
1 
2 
3 


6 4 
6 1 
6 2 
6 3 


Group 3: Increment 1 
Increment 2 


10 1 
10 2 


8 
8 


1 
2 


9 1 
9 2 



*The Shift Unit is sometimes required to store two results at one time: one Into an 
X register and one into a B register. 
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TABLE B-3. 6600/6700 REGISTER RESERVATION CONTROL 



INSTRUCTION 



Branch Unit 
02ijK 
03ijK 
04ijK 

Boolean Unit 
lOijk - 17ijk 

Shift Unit 

20ijk - 23ijk 
24ijk - 26ijk 
27ijk&43ijk 

Add Unit (Floating) 
30ijk - 35ijk 

Long Add (Integer) 
36ijk - 37ijk 

Multiply (2 Units) 
40ijk - 42ijk 

Divide Unit 

44ijk - 47ijk 

Increment (2 Units) 
50ijK 
51ijK 
52ijK 
53ijk 

54ijk & 55ijk 
5 6ijk &57ijk 
60ijK 
61ijK 
62ijK 
63ijk 

64ijk & 65ijk 
66ijk & 67ijk 
70ijK 
71ijK 
72ijK 
73ijk 

74ijk & 75ijk 
76ijk &77ijk 



XBA RESULT 
REGISTER (ISSUE) 



Q OPERAND 
REGISTER (EXECUTION) 



Xi 



Xi 

Xi &Bj 

Xi 



Xi 



Xi 



Xi 



Xi 



Ai &Xi 

Ai &Xi 

Ai &Xi 

Ai &Xi 

Ai &Xi 

Ai &Xi 

Bi 

Bi 

Bi 

Bi 

Bi 

Bi 

Xi 

Xi 

Xi 

Xi 

Xi 

Xi 



Bi &Bj 
Xi&Xj 
Bi &Bj 



Xj &Xk 



Bj &Xk 
Bj &Xk 
Bj & Xk 



Xj &Xk 
Xj &Xk 
Xj &Xk 
Xj &Xk 



Aj & Bk 
Bj &Bk 
Xj & Bk 
Xj &Bk 
Aj &Bk 
Bj & Bk 
Aj &Bk 
Bj &Bk 
Xj &Bk 
Xj &Bk 
Aj &Bk 
Bj &Bk 
Aj &Bk 
Bj &Bk 
Xj &Bk 
Xj &Bk 
Aj &Bk 
Bj- & Bk 



i=* 



* The Xi register is considered only when i = 1, 2. . . 7. 
** k here refers to the high order 3 bits of 18-bit address field. 



B-13 



Rev K 



PERIPHERAL AND CONTROL PROCESSOR 

The execution time of Peripheral and Control Processor instructions is influenced by 
the following factors: 

• Number of memory references - indirect addressing and indexed 
addressing require an extra memory reference. Instructions in 
24-bit format require an extra reference to read m. 

• Number of words to be transferred - in I/O instructions and in 
references to Central Memory the execution times vary with the 
nunnber of words to be transferred. The maximum theoretical 
rate of flow is one word/major cycle. I/O word rates depend 
upon the speed of external equipments which are normally much 
slower than the computer. 

• References to Central Memory may be delayed if there is conflict 
with Central Processor memory requests. 

• Following an Exchange Jump instruction, no memory references 
(nor other Exchange Jump instructions) may be made until the 
Central Processor has completed the Exchange Jump. 

TABLE B-4. PERIPHERAL AND CONTROL PROCESSOR 
INSTRUCTION EXECUTION TIMES 



OCTAL 




TIME* 


CODE 


NAME 


(MAJOR 
CYCLES) 


00 


Pass 


1 


01 


Long jump to m + (d) 


2-3 


02 


Return jump to m + (d) 


3-4 


03 


Unconditional jump d 




04 


Zero jump d 




05 


Nonzero jump d 




06 


Plus jump d 




07 


Minus jump d 




10 


Shift d 




11 


Logical difference d 




12 


Logical product d 




13 


Selective clear d 




14 


Load d 
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*Note that the shorter time is taken in certain instructions 
when d = 0, 
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TABLE B-4. (Cont'd) 



OCTAL 




TIME* 


CODE 


NAME 


(MAJOR 
CYCLES) 


15 


Load complement d 


1 


16 


Add d 


1 


17 


Subtract d 


1 


2G 


Load dm 


2 


21 


Add dm 


2 


22 


Logical product dm 


2 


23 


Logical difference dm 


2 


24 


Pass 


1 


25 


Pass 


1 


260 


Exchange jump 


2. '•''T' 


27 


Read program address 


1 


30 


Load (d) 


2 


31 


Add (d) 


2 


32 


Subtract (d) 


2 


33 


Logical difference (d) 


2 


34 


Store (d) 


2 


35 


Replace add (d) 


3 


36 


Replace add one (d) 


3 


37 


Replace subtract one (d) 


3 


40 


Load ((d)) 


3 


41 


Add ((d)) 


3 


42 


Subtract ((d)) 


3 


43 


Logical difference ((d)) 


3 


44 


Store ((d)) 


3 


45 


Replace add ((d)) 


4 


46 


Replace add one ((d)) 


4 


47 


Replace subtract one ((d)) 


4 


50 


Load (m + ((d)) 


3-4 


51 


Add (m + (d)) 


3-4 


52 


Subtract (m + (d)) 


3-4 


53 


Logical difference (m + (d)) 


3-4 


54 


Store (m + (d)) 


3-4 



*Note that the shorter time is taken in certain instructions 
when d = 0, 



**Though the execution time for this instruction in the Peripheral 
and Control Processor is only 1 major cycle, a minimium of 2 
major cycles is required to complete the Exchange operation in 
Central Memory. Thus, Central Mennory honors no requests 
for access for a minimum of 2 major cycles during an Exchange 
Jump. 
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TABLE B-4. (Cont'd) 



OCTAL 




TIME* 


CODE 


NAME 


(MAJOR 
CYCLES) 


55 


Replace add (m + (d)) 


4-5 


56 


Replace add one (m + (d)) 


4-5 


57 


Replace subtract one (m + (d)) 


4-5 


60 


Central read from (A) to d 


min. 6 


61 


Central read (d) words 


5 plus 




from (A) to m 


5 /word 


62 


Central write to (A) from d 


min. 6 


63 


Central write (d) words 


5 plus 




to (A) from m 


5 /word 


64 


Jump to m if channel d active 


2 


65 


Jump to m if channel d inactive 


2 


66 


Junap to m if channel d full 


2 


67 


Jump to m if channel d empty 


2 


70 


Input to A from channel d 


2 


71 


Input (A) words to m 


4 plus 




from channel d 


l/word 


72 


Output from A on channel d 


2 


73 


Output (A) words from m 


4 plus 




on channel d 


l/word 


74 


Activate channel d 


2 


75 


Disconnect channel d 


2 


76 


Function (A) on channel d 


2 


77 


Function m on channel d 


2 



*Note that the shorter time is taken in certain instructions 
when d = 0. 
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Appendix C 

NON-STANDARD FLOATING 
POINT ARITHMETIC 



NON-STANDARD FLOATING POINT ARITHMETIC 

The following is a tabulation of operations (Add, Subtract, Multiply, Divide) using various 
combinations of operands to supplement Table 3-3 (page 3-13). The key to operands and 
results used in the table is as follows: 
KEY: 



OPERANDS 


RESULTS 


+0 


OOOOX...X 







0000 0. . .0 


-0 


7777X...X 




IND 


1777 0. .,0 


+ CD 


3777X...X 




+ CO 


= 3777 0.,.0 


- 00 


4000X, .,X 




- CO 


4000 0, . .0 


+IND 


1777X,..X 








-IND 


6000X. ..X 








W 


= Any word except ± OD 


, ±IND 






N 


Any word except ±oo 


, ±IND, or ±0 







ADD 

Xi=X3+Xk 
(Instructions 30, 32, 34) 







Xk 1 




W 


+ 00 


- 00 


±IND 




w 


- 


+ 00 


- 00 


IND 


Xj 


+ C0 




+ 00 


IND 


IND 


-00 




IND 


-co 


IND 




±IND 








IND 



SUBTRACT 

Xi=Xj-Xk 
(Instructions 31, 33, 35) 







Xk 1 




W 


+ 00 


- 00 


±IND 




w 


- 


- 00 


+ 00 


IND 


Xj 


+ 00 


+ 00 


IND 


+ 00 


IND 


-co 


- 00 


-00 


IND 


IND 




±IND 


IND 


IND 


IND 


IND 
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MULTIPLY 

Xi=Xj*Xk 
(Instructions 40, 41, 42) 







Xk 1 




+N -N +0 


-0 


+ C0 


-CO 


±IND 




+N 








+ CD 


-00 


IND 




-N 








-co 


+ 00 


IND 




+0 








IND 


IND 


IND 


Xj 


-0 







IND 


IND 


IND 




+ C0 






+ 00 


- 00 


IND 




-00 








+ 00 


IND 




±IND 










IND 



DIVIDE 

Xi=Xi/Xk 
(Instructions 44, 45) 







Xk 1 




+N 


-N 


+0 


-0 


+ 00 


-00 


±IND 




+N 


- 


- 


+ 00 


-00 








IND 




-N 


- 


- 


- GO 


+ 00 








IND 




+0 








IND 


IND 


Q 





IND 


Xj 


-0 








IND 


IND 








IND 




+ 00 


+ 00 


-00 


+ 00 


-00 


IND 


IND 


IND 




-00 


-co 


+ 00 


- 00 


+ 00 


IND 


IND 


IND 




±IND 


IND 


IND 


IND 


IND 


IND 


IND 


IND 
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Appendix D 
COMPASS MNEMONICS 



ASCENT MNEMONICS 

Each operation is defined by listing the mnemonic, each subfield, the octal representa- 
tion of the operation, and the instruction length in bits. Instructions are listed in 
order of octal operation value. An entry is given for each permissible variable field 
format. In the operation field and variable field subfield notations, the following 
symbology is used: 

Xi, Xj, Xk X register symbols. The number of the register is 

placed in the i, j, or k portion. 

Ai, Aj, Ak A register symbols 

Bi, Bj, Bk B register symbols 

K address expression (18 bits) 

n absolute address (6 bits) 



Length 


Mnemonic 


Variable Field 


Octal 


30 


PS 


0000 000000 


30 


RJ 


K 




0100 K 


30 


REC 


Bj, 


K 


Ollj K 


30 


WEC 


Bj, 


K 


012j K 


60 


XJ 






0130 000000 
46000 46000 


30 


JP 


K 




0200 K 


30 


JP 


Bj 


+ K 


020j K 


30 


ZR 


Xj, 


K 


030j K 


30 


NZ 


Xj, 


K 


031j K 


30 


PL 


Xj, 


K 


032] K 


30 


NG 


Xj, 


K 


033j K 


30 


IR 


Xj, 


K 


034j K 


30 


OR 


Xj, 


K 


035j K 


30 


DF 


Xj, 


K 


036j K 


30 


ID 


Xj, 


K 


037] K 


30 


ZR 


K 




0400 K 


30 


EQ 


K 




0400 K 


30 


EQ 


Bi, 


K 


04i0 K 


30 


ZR 


Bi, 


K 


04i0 K 
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Length 


Mnemonic 


Variable Field 


Octal 


30 


EQ 


Bi, 


Bj, K 






04ij K 


30 


NZ 


Bi, 


K 






05i0 K 


30 


NE 


Bi, 


K 






05i0 K 


30 


NE 


Bi, 


Bj, K 






5ij K 


30 


PL 


Bi. 


K 






06i0 K 


30 


GE 


Bi, 


K 






06i0 K 


30 


GE 


Bi, 


Bj, K 






06ij K 


30 


LE 


Bj, 


K 






060j K 


30 


LE 


Bj, 


Bi, K 






06ij K 


30 


NG 


Bi, 


K 






07i0 K 


30 


LT 


Bi. 


K 






07i0 K 


30 


LT 


Bi, 


Bj. K 






07ijK 


30 


GT 


Bj, 


K 






070j K 


30 


GT 


Bj, 


Bi, K 






07ij K 


15 


BXi 


Xj 








lOijj 


15 


BXi 


Xj^ 


* Xk 






llijk 


15 


BXi 


xj- 


4- Xk 






12ijk 


15 


BXi 


Xj 


- Xk 






13ijk 


15 


BXi 


-Xk 






14ikk 


15. 


BXi 


-Xk * Xj 






15ijk 


15 


BXi 


-Xk + Xj 






16ijk 


15 


BXi 


-Xk - Xj 






17ijk 


15 


LXi 


n 








20i n 


15 


AXi 


n 








21i n 


15 


LXi 


Bj, 


Xk, or Xk 


. Bj 


22ijk 


15 


AXi 


Bj. 


Xk or 


Xk, 


Bj 


2 3ijk 


15 


NXi 


Xk 








24i0k 


15 


NXi 


Bj, 


Xk or 


Xk, 


Bj 


24ijk 


15 


ZXi 


Xk 








2 5i0k 


15 


ZXi 


Bj, 


Xk or 


Xk, 


Bj 


2 5ijk 


15 


UXi 


Xk 








26iOk 


15 


UXi 


Bj. 


Xk or 


Xk, 


Bj 


26ijk 


15 


PXi 


Bj, 


Xkor 


Xk, 


Bj 


2 7ijk 


15 


FXi 


Xj- 


f Xk 






30ijk 


15 


FXi 


Xj ■ 


- Xk 






31ijk 
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Length 


Mnemonic 


Variable Field 


Octal 


15 


DXi 


Xj +Xk 






32ijk 


15 


DXi 


Xj -Xk 






33ijk 


15 


RXi 


Xj +Xk 






34ijk 


15 


RXi 


Xj - Xk 






35ijk 


15 


IXi 


Xj + Xk 






36ijk 


15 


IXi 


Xj - Xk 






37ijk 


15 


FXi 


Xj * Xk 






40ijk 


15 


RXi 


Xj * Xk 






41ijk 


15 


DXi 


Xj * Xk 






42ijk 


15 


MXi 


n 






43i n 


15 


FXi 


Xj/Xk 






44ijk 


15 


RXi 


Xj/Xk 






45ijk 


15 


NO 








46000 


15 


CXi 


Xk 






47ikk 


30 


SAi 


Aj+K 






50ij K 


30 


SAi 


K 






51i0 K 


30 


SAi 


Bj + K 






51ij K 


30 


SAi 


Xj +K 






52 ij K 


15 


SAi 


Xj 






53ijO 


15 


SAi 


Xj + Bk or 


Bk + 


Xj 


53ijk 


15 


SAi 


Aj 






54ijO 


15 


SAi 


Aj + Bk or 


Bk + 


Aj 


54ijk 


15 


SAi 


Aj - Bk or 


-Bk + Aj 


55ijk 


15 


SAi 


Bj 






56ij0 


15 


SAi 


Bj + Bk 






56ijk 


15 


■ SAi 


-Bk 






57i0k 


15 


SAi 


Bj - Bk or 


-Bk + Bj 


57ijk 


30 


SBi 


Aj+K 






60ij K 


30 


SBi 


K 






61i0 K 


30 


SBi 


Bj+K 






61ij K 


30 


SBi 


Xj + K 






62ij K 


15 


SBi 


Xj 






63ijO 


15 


SBi 


Xj + Bk or 


Bk + 


Xj 


63ijk 


15 


SBi 


Aj 






64ij0 


15 


SBi 


Aj + Bk or 


Bk + 


Aj 


64ijk 
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Length 


Mnemonic 


Variah 


lie 


Field 




Octal 


15 


SBi 


Aj - Bk 


or 


-Bk + 


Aj 


65i]k 


15 


SBi 


Bj 








66i]0 


15 


SBi 


Bj+ Bk 








66ijk 


15 


SBi 


-Bk 








67i0k 


15 


SBi 


Bj - Bk 


or 


-Bk + 


Bj 


67ijk 


30 


SXi 


Aj + K 








70ij K 


30 


SXi 


K 








71i0 K 


30 


SXi 


Bj + K 








71ij K 


30 


SXi 


Xj+K 








72ij K 


15 


SXi 


Xj 








73ijO 


15 


SXi 


X3+ Bk 


or 


Bk+ Xj 


73ijk 


15 


SXi 


Aj 








74ij0 


15 


SXi 


A] + Bk 


or 


Bk+ Aj 


74ijk 


15 


SXi 


Aj - Bk 


or 


-Bk + 


Aj 


75ijk 


15 


SXi 


Bj 








76ijO 


15 


SXi 


Bj + Bk 








76ijk 


15 


SXi 


-Bk 








77i0k 


15 


SXi 


Bj - Bk 


or 


-Bk + 


Bj 


77ijk 
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PERIPHERAL PROCESSOR MNEMONICS t 



Machine Instruction 

PSN 

LJM M, d 

RJM M, d 

UJN r 

ZJN r 

NJN r 

PJN r 

MJN r 

SHN d 

LMN d 

LPN d 

SCN d 

LDN d 

LCN d 

ADN d 

SBN d 

LDC C 

ADC C 

LPC C 

LMC C 
PSN 
PSN 

EXN d 

MXN d 

RPN d 

LDD d 

ADD d 

SBD d 

LMD d 

STD d 

RAD d 

AOD d 

SOD d 



t Notations: M = 12 -bit address value, C = 18 
r = value between -31 and +31 



Octal Value 

0000 

Oldd MMMM 
02dd MMMM 
03rr 
04rr 
05rr 
06rr 
07rr 
lOdd 
lldd 
12 dd 
13dd 
14dd 
15dd 
16dd 
17dd 

20CC CCCC 
2 ICC CCCC 
22CC CCCC 
2 3CC CCCC 
2400 
2500 
260x 
261x 
270d 
30dd 
31dd 
32 dd 
33dd 
34dd 
35dd 
36dd 
37dd 
■bit address value, d = 6 -bit index value, 
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Machine Instruction 



Octal Value 



LDI 


d 




ADI 


d 




SBI 


d 




LMI 


d 




STI 


d 




RAI 


d 




AOI 


d 




SOI 


d 




LDM 


M, 


d 


ADM 


M, 


d 


SBM 


M, 


d 


LMM 


M, 


d 


STM 


M, 


d 


RAM 


M, 


d 


AOM 


M, 


d 


SOM 


M, 


d 


CRD 


d 




CRM 


M, 


d 


CWD 


d 




CWM 


M, 


d 


AJM 


M, 


d 


IJM 


M, 


d 


FJM 


M, 


d 


EJM 


M, 


d 


IAN 


d 




lAM 


M, 


d 


OAN 


d 




OAM 


M, 


d 


ACN 


d 




DCN 


d 




FAN 


d 




FNC 


M, 


d 



40dd 




41dd 




42dd 




43dd 




44dd 




45dd 




46dd 




47dd 




50dd 


MMMM 


51dd 


MMMM 


52dd 


MMMM 


53dd 


MMMM 


54dd 


MMMM 


55dd 


MMMM 


56dd 


MMMM 


57dd 


MMMM 


60dd 




61dd 


MMMM 


62dd 




63dd 


MMMM 


64dd 


MMMM 


65dd 


MMMM 


66dd 


MMMM 


67dd 


MMMM 


70dd 




71dd 


MMMM 


72dd 




73dd 


MMMM 


74dd 




75dd 




76dd 




77dd 


MMMM 
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Appendix E 

CONTROL DATA 6415-7, 6415-8 AND 6415-9 
CENTRAL COMPUTER SYSTEMS 



CONTROL DATA 64XX-7, 64XX-8 and 64XX-9 



DESCRIPTION 

The Control Data® 64XX-7, 64XX-8, and 64XX-9* are three versions of the 6400 
Computer System that are available with the following system configuration: 

64XX-9 - Central Computer with ECS Coupler, nine FPU's, and eleven data 

channels . 
64XX-8 - Central Computer with ECS Coupler, eight PPU's, and ten data 

channels . 

64XX-7' - Central Computer with ECS Coupler, seven FPU's, and nine data 
channels . 

The FPU's and Data Channels removed for each system described above are illustrated 
by Table E-1. 

TABLE E-1. REMOVED FPU's AND DATA CHANNELS 



SYSTEM 


PPU'S REMOVED 


DATA CHANNELS REMOVED 


6 4XX-7 


5 6 7 


5 6 7 


64XX-8 


6 7 


6 7 


64XX-9 


7 


7 



DATA. CHANNEL STATUS 



The Data Channels removed remain INACTIVE and EMPTY, and cannot be activated. 



PERIPHERAL PROCESSING UNIT STATUS 



The FPU's removed are referenced normally on Dead Start but exit from a 712 instruc- 
tion during the first trip, when the INACTIVE condition is sensed on the .corresponding 
Data Channel. The program address 0001„ is then sent to the removed FPU's memory, 
and all sevens are "read". The FPU then attempts to function Channel 77. 

*These computers are available with memory sizes of 32K, 49K, 65K, 98K and 131K. i 
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APPENDIX F 

CENTRAL EXCHANGE JUMP (CEJ) AND MONITOR EXCHANGE JUMP (MEJ) 
CENTRAL MEMORY ACCESS PRIORITY (CMAP) 



CENTRAL, EXCHANGE JUMP (CEJ) AND MONITOR EXCHANGE JUMP (MEJ) 

In CONTROL DATA 6000 Series Computer Systems, system functions are normally 
handled by the Monitor located in a Peripheral and Control Processor. The Computer 
Systems are equipped with certain hardware capabilities to effectively implement 
Monitor activities in the Central Processor. Since the Central Processor can reference 
Extended Core Storage directly for service routines, programs and data, a Central 
Processor Monitor program to handle these and other functions is faster and more 
efficient than a Monitor residing in a Peripheral and Control Processor. 

The hardware elements which provide the essential capabilities for implementing a 
Central Processor Monitor are described in the ensuing paragraphs. 

MONITOR ADDRESS REGISTER 

Contained in the Exchange Jump package (bits 36-53 of location "n+6") is an 18-bit 
Monitor Address. Just as other Central Processor operational registers are loaded 
during an Exchange operation, so is the Monitor Address register loaded with the 
18-bit Monitor Address. This Monitor Address is the starting address of the Exchange 
package for an ensuing Central Exchange Jump instruction (except when the Monitor 
Flag bit is set; refer to the instruction description). 



MONITOR FLAG BIT 

The Central Processor has, in the Central Memory control section of the system, 
a Monitor Flag bit. A Master Clear (Dead Start) clears the Monitor Flag bit. Any 
action thereafter on this bit is via the Monitor Exchange or the Central Exchange Jump 
instructions. (There is no instruction with which to sample the status of this bit directly 
and/or independently of these instructions. ) The operation of this Monitor Flag bit is 
described under the instraction descriptions. 
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MONITOR AND CENTRAL EXCHANGE JUMP INSTRUCTIONS 

Two instructions exist for Central Processor monitor implementation: 

one executable by the Peripheral Processors; the other executable by the Central 
Processor. These instructions are as detailed below. 



Peripheral Processors 

261 MXN Monitor Exchange Jump 



11 



F 



(12 bits) 




3 2 1 

Not Used 



(Dual CP Bit) 



This instruction, typically used to initiate Central Processor Monitor activity, is a 
conditional exchange jump to the Central Processor. If the Monitor Flag bit is clear, 
this instruction sets the flag and initiates the exchange. If the Monitor Flag bit is set, 
this instruction acts as a Pass instruction. The starting address for this exchange is 
the 18-bit address held in the Peripheral Processor A register. (The Peripheral 
Processor program must have loaded A with an appropriate address prior to executing 
this instruction. ) Note that this starting address is an absolute address. In the 6500 
and 6700 this instruction is either 2610 (CPU-0) or 2611 (CPU-1). 



Central Processor 
013 XJ 



JK 



Central Exchange Jump 



(60 bits) 



fmi 


J 


K 


Not Used 



60 



51 50 



48 



47 



30 29 



This instruction unconditionally exchange jumps the Central Processor, regardless 
of the state of the Monitor Flag bit. Instruction action differs, however, depending 
on whether the Monitor Flag bit is set or clear. Operation is as follows: 

a) Monitor Flag bit clear. The starting address for the exchange is taken from 
the 18 -bit Monitor Address register. Note that this starting address is an 
absolute address. During the exchange, the Monitor Flag bit is set. 
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b) Monitor Flag bit set. The starting address for the exchange is the 18-bit 
result formed by adding K to the contents of register Bj. Note that this 
starting address is an absolute address. During the exchange, the Monitor 
Flag bit is cleared. 

Table 1 summarizes the operational differences between the normal Exchange Jump 
instruction (260) and the Monitor and Central Exchange Jumps (261 and 013). 

TABLE 1-1. EXCHANGE INSTRUCTION DIFFERENCES 



INSTRUCTION 


CONDITIONAL/ 
UNCONDITIONAL 


OPERATIONAL DIFFERENCES 


Effect on 
Monitor Flag Bit 


Location of Starting 
Address for Exchange 


260 (Normal Peri- 
pheral Processor 
Exchange Jump) 

261 (Peripheral Pro- 
cessor Monitor 
Exchange Jump) 

013 (Central Ex- 
change Jump) with 
Monitor Flag Bit 
clear 

013 (Central Ex- 
change Jump) with 
Monitor Flag Bit 
set 


Unconditional 

Conditional 
(occurs only if 
Monitor Flag 
bit is clear; 
Passes if Flag is 
set) 

Unconditional 
Unconditional 


No effect on Flag 
Sets Flag 

Sets Flag 
Clears Flag 


Peripheral Processor 
A Register 

Peripheral Processor 
A Register 

Central Processor 
Monitor Address 
Register 

Address formed by 
K+(Bj) 
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PROGRAMMING NOTES 

1) The Exchange package is precisely as described under Access to Central 
Memory in Section 4, with the single exception that bits 36-53 of location 
"n+6" hold a Monitor Address. Note that any exchange (260, 261, or 013) to 
that package will load the contents of location "n+6" into the Monitor Address 
register (other operational registers are similarly loaded). Thus, any 
ensuing 013 instruction using the contents of the Monitor Address register 
as a starting address uses those contents as loaded. 

2) The Exchange packages for entering the Central Processor Monitor should 
usually have the Reference Address (RA) equal to 000000 and the Field Length 
(FL) equal to Central Memory size. 

3) Since the Monitor Flag bit cannot directly sampled, a program cannot directly 
determine its state; hence, success in performing a Peripheral Processor 
Monitor Exchange cannot readily be predicted. Further, program control 
always is given to the next instruction, whether or not the Exchange is 
honored. A method of determining whether the Monitor Exchange occurred is 
as follows: 

a) Set BO (bits 0-17 of location "n") in the Exchange package to 7777 

b) Initiate the Monitor Exchange (261) 

c) Read BO from the Exchange package in Central Memory, If the 
Monitor Exchange was honored, BO in the Exchange package will 
equal 000000. If the instruction passed, this location still holds 
7777. 

4) Different Exchange packages should be used for Central Processor exchanges 
and Peripheral Processor exchanges. This aids software determination of 
which of two jumps (Central or Monitor Exchange Jumps) was executed when 
both were initiated at approximately the same time. 

5) Simultaneous Exchange requests are resolved in favor of the Central Processor. 

6) If either a 260 or 261 instruction is waiting to be honored, when the Central 
Processor issues an 013 K instruction, the 013 instruction is not executed 
and the Peripheral Processor Exchange occurs. When control is returned 
to the exchanged program (the interrupted program containing the 013 jK 
instruction), the 013jK instruction is re-issued and executed. 
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7) The state of the Monitor Flag bit has no effect on the operation of the normal 
PP Exchange Junap (260); nor has this instruction any effect on the Flag. 

ADDITIONAL PROGRAMMING NOTES FOR 6 500 AND 6700 

1. When one CPU is in monitor mode, a Monitor Exchange Jump to either CPU 
will be aborted. Since the exchange was never started, the instruction is in 
effect a pass. 

2. When one CPU is in Monitor mode, a Central Exchange Jtimp from the second 
CPU will hang until the first CPU's monitor flag is cleared. 

3. If a regular exchange jump (2600) is executed with MEJ/CEJ instructions it 
is possible to cause both Monitor Flags to set. This condition could cause 
both CPU's to hang on CEJ instructions. 

4. An ECS Transfer In Progress will block a Central Exchange Jump from 
either CPU. 

5. A Monitor Exchange Jump to a CPU that has an ECS Transfer In Progress is 
allowed. A Monitor Exchange Jump to the other CPU, however, will be 
aborted until the first CPU has completed the ECS transfer. 

Items 4 and 5 above are consistent with the dual access concept of the 6500/6700 
coupler, i. e. , if one CPU is executing an ECS instruction, the other CPU is blocked 
when doing any type of memory reference until the ECS transfer is complete. A 
normal exchange jump to a CPU doing an ECS transfer will terminate the ECS trans- 
fer and execute the exchange jump. A normal exchange jump to the other CPU will 
be withheld until the ECS transfer is finished in the first CPU. 
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CENTRAL MEMORY ACCESS PRIORITY (CMAP) 

DESCRIPTION 

Central Memory Access Priority (CMAP) provides a Peripheral Processor (PP) 
which has been previously designated a Priority PP with the ability to interrupt ECS 
transfers. CMAP also gives a PP, so designated, preference over non-priority PPs 

in the execution of Central Read and Central Write instructions when ECS is inactive. 

17 
Priority status is assigned to a processor by setting bit (2 ) of its A register. CMAP 

is included with the 6700 and is available as a standard option for other 6000 Systems. 



CMAP EFFECT ON ECS 

Without CMAP, any PP requesting Central Memory interrupts an ECS transfer. 
Because one PP request is honored for every ECS record, if several PP Central 
Memory requests were to occur during an ECS transfer, they could reduce the trans- 
fer rate significantly (A500K-ECS system by 75% and a 2 50K-ECS system by 50%; a 
12 5K-ECS system would not be affected). 

Besides a degraded transfer rate, a critically required PP request can experience 
unreasonable delay, giving undesirable effects in the operation of various I/O drivers 
and causing some jobs to run slower when ECS is active. 

However, with CMAP, non-priority reads and writes are prevented from entering the 
read and write pyramids while an ECS transfer is under way. Only priority requests 
for Central Memory are enabled during an ECS transfer. Generally, only priority 
requests are honored during an ECS TRANSFER but a few instances exist in which a 
non-priority request is honored during an ECS transfer. These are described below. 

It is possible to have non-priority reads or writes in progress at the time ECS becomes 
active. Several non-priority writes could be trapped in the write pyramid or either 
a non-priority read or a non-priority write could be hung up on the ECS coupler. A 
read or write hung up in the coupler will be serviced during the ECS transfer. 
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Writes hung up in the write pyramid would not be serviced until the ECS transfer is 
completed, or until a priority write comes up. Requests following these special cases 
will be priority requests. One request (priority or non-priority) is honored per ECS 
record. 

The possibility also exists that a non-priority read or write could be in progress in 
Central Memory Control at the time ECS becomes active. The existence of a request 
in such a condition is allowed to interrupt ECS. 



CMAP EFFECT ON PP READS AND WRITES WITH ECS INACTIVE 

Priority Write 

CMAP allows a PP to place a reservation for D. during trip 620 or trip 633 of the 
write instruction. This reservation is cleared during the 620 or 633 trip if D^ is 
found available. The reservation keeps any non-priority write out of D^ and prevents 
any non-priority read from setting Central Busy. The priority write, therefore, 
should be serviced in a few major cycles (usee. ). 

Priority Read 

CMAP allows a PP to place a reservation for C and Central Busy during the 612 trip 
or the 600 trip of the read instruction. This reservation is cleared during the 612 or 
600 trip if C is empty and Central is not Busy. If it is not cleared, any non-priority 
PP is prevented from setting Central Busy. The Priority read, therefore, should be 
serviced within a few major cycles (usee. ). 

To provide the above capabilities, a change is required in the read pyramid. 

Read Operation Before Modification 

A Central Read instruction is normally executed when the following combination of 
conditions occurs: 

1. Central Busy FF is clear. 

2. C (60-bit register) of the read pyramid is empty. 

3. One additional register of the read pyramid (C"*" - C^) is also empty, except 
when doing a Block Read (61 instruction). 
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Assume, for example, that PPO is doing a Block Read (61 instruction), PPl is doing 

a One Word Read (60 instruction), and PP2, PP3, PP4, and PP5 are all doing Block 

12 3 

Reads. At a specific point in time, PPO is in C , PPl is in C , PP2 is in C , and 

4 5 5 

PP3 is in C , PP4 cannot get into C until one of the lower registers is empty, C 

is empty, and the Central Busy FF is clear. If PPO finds a conflict* during trip 617 

of the Block Read instruction, the other PPs cannot advance until the next lower 

2 
pyramid register is empty. Using the above stated conditions, the PP at C is execut- 
ing a One Word Read and it must wait until PPO is finished. It should not have to wait 
because it no longer requires Central Memory. Also, once PPO unloads C , it has a 
greater chance of re-entering C before PP4 can. This means that One Word Read 
instructions could be excessively delayed under some circumstances and that entrance 
into the read pyramid is not a true random selection of all the PPs. 

Read Operation After Modification 

1 ■ 

CMAP modifies the Read operations to provide all the PPs with an equal opportunity 
for entry into the read pyramid. Using the conditions stated in Example A with PPO 
in C doing a Block Read, the possibility for conflict at trip 617 is eliminated. This 
is accomplished by unconditionally unloading C into the PP Memory whenever a 
Block Read arrives at the 617 trip, regardless of the word count in Q. If the Block 
Read is not complete and a Central Busy or C conflict exists during the 617 trip, the 
instruction is forced back to a 612 trip and an additional bit of K is set. This new bit 
of K (termed a Flag bit) indicates to the Block Read that the forced 612 trip is not the 
first iteration of the instruction. The status of the Flag bit causes the proper transfers 
to take place during execution of the 612 portion of the instruction. The unconditional 
unloading of C eliminates the need for sensing an Empty condition in the next lower 
register before advancing the trip count of the instruction. One Word Reads can thus 
flow, without restriction, through the pyramid during disassembly. The Block Read 
instructions function as before if no conflict is found at trip 617. 



5 
^Central Busy set or C full; however in this example only a Central Busy condition 

caused by a Central Processor request or an Exchange Jump would apply. 
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A register. 

Central Processor, 3-6, 3-7 

Peripheral Processor, 4-8 
Absolute memory address, 2-3 
Access to the Central Processor, 4-34 
Adders, Peripheral and Control Processors, 
Address, 

absolute, 2-3 

Central Memory, 2-1 

modes, 4-6 

program, 3-8 

relative, 2-3 

reference, 2-2 
Arithmetic, 

fixed point, 3-21 

floatingpoint, 3-15 
Arithmetic unit, 3-1 
Augmented Input/Output Buffer and Control, 

systems configuration, A- 2, A-3 

instructions, A-4 



B register. Central Processor, 3-6 
Barrel, 4-4 

registers, 4-8 
Banks, Central Memory, 2-1 
Block transfer, 4-2, 4-29, 4-30, 4-32, 
Branch instructions, 3-43 



4-4 



A-1 



4-33, 4-34 



Central Memory, 1-2 

access, 2-1, 4-32 

address format, 2-1 

characteristics, 1-6 

map, 2-3 

organization, 2-1 

protection, 2-2 

read, 4-3 2 

write, 4-33 
Central Processor, 1-1, 1-2 

characteristics, 1-4 

comparisons in 6000 Series, 3-1 

Exchange Jump, 3-9 

Exit mode, 3-11 

fixed point arithmetic, 3-21 

floating point arithmetic, 3-15 

functional units, 3-4 

instruction descriptions, 3-22 

instruction execution times, B-6 

instruction formats, 3-4 

operating registers 

organization, 3-1 

programming, 3-3, 

timing notes, B-9 
Clock, see Real-Time Clock 
Coefficient, 3-15, 3-16, 3-35 
Concurrency, 1-2 
Console, see Display Console 



Data, 

distributor, 2-2 

input, 4-37 

output, 4-38 
Data Channels, 1-6, 4-35 

active /inactive, 4-31, 4-36 

full/ empty, 4-2 8, 4-36 

input, 4-29, 4-37 



3-2, 3-6 
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output, 4-30, 4-38 

word rate, 4-36 
Data Channel Converter, 1-3 
Dead start panel, 6-1 

photo graph, 6-3 
Disk System, 1-3 
Display Console, 1-3, 6-1, 6-4 

characteristics, 1-7 

photograph, 6-5 

sample display, photograph, 6-6 
Dot mode, 6-4 
Double precision, 3-16 



Exchange Jump, 2-3, 3-3, 3-9, 3-51, 5-1 

instruction, 4-34 

package, 3-9 
Exit mode, 3-11, 5-2 

table, 3-13 
Exponent, 3-15, 3-16, 3-35 
Extended Core Storage, instructions, 3-46 



Field Length, 2-3, 3-9, 3-47, 3-48 
Fixed point arithmetic, 3-21, 3-22 

instructions, 3-28 
Flags, 4-2, 4-36 
Floating point arithmetic, 3-15 

converting integers to floating format, 3-19 

instructions, 3-37 

non-standard, C-1 

overflow and underflow conditions, 3-19, 3-20 
Functional units. Central Processor, 3-5 



Hopper, 2-2 



Indefinite forms, 3-17, 3-18, 3-19 

see also Floating Point Arithmetic, non- 
standard, C-1 
Input/Output, 4-2, 4-25 

channels, 4-2 

see also Data Channels 

data flow, 4-1 

data input, 4-37 

data output, 4-38 
Interrupt, 5-1 

hardware provisions, 5-1 
Instructions, Central Processor, 

Branch, 3-43, 3-44, 3-45 

execution, 3-3 

execution times, B-6 

Extended Core Storage, 3-46 

fixed point arithmetic, 3-21 

floatingpoint, 3-37, 3-38, 3-39, 3-40, 3-41, 3-42 

formats, 3-4, 3-5 

Increment, 3-24, 3-25, 3-26 

Logical, 3-29, 3-30, 3-31, 3-32 

Mask, 3-36 

No Operation, 3-23 

Normalize, 3-34 

Notes on timing, B-9 

Pack, 3-36 

Program Stop, 3-23 

Round and Normalize, 3-34 

Shift, 3-32, 3-33 
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Stack, 3-4, 3-10 

Unpack, 3-35 
Instructions, Peripheral and Control Processors, 

access to Central Memory, 4-32, 4-33, 4-34 

Arithmetic, 4-13, 4-14, 4-15, 4-16 

Branch, 4-22, 4-23, 4-24 

Central Processor and Central Memory, 4-24, 4-25 
4-26, 4-27 

Data Transmission, 4-11, 4-12, 4-13 

execution times, B-14 

formats, 4-6 

input/output, 4-27, 4-28, 4-29, 4-30, 4-31, 4-32, 
4-35 

Logical, 4-16, 4-17, 4-18, 4-19 

No Operation, 4-10 

Replace, 4-19, 4-20, 4-21, 4-22 

Shift, 4-16 
Instruction execution times, B-1, B-9 

Central Processor table, B-6 

Peripheral and Control Processor table, B-14 



characteristics, 1-5 

input / output, 4-35 

input /output (I/O) channels, 4-2 

instruction descriptions, 4-10 

Instruction formats, 4-6 

organization, 4-1 

programming, 4-4 

real-time clock, 4-3, 4-39 

registers, 4-8 

slot, 4-4 
Program Address register. 

Central Processor, 3-8 

Peripheral and Control Processor, 4-9 
Programs, Central Processor, 3-3 
Pyramid, 

read, 4-5, 4-32 

write, 4-5, 4-33 



Q register. Peripheral and Control Processor, 4-9 



Jump, see Branch 



K register. Peripheral and Control Processor, 4-9 
Keyboard input, 6-4 



Magnetic tape transport, 1-3 

Manual control, 6-1 

Mass memory, see Extended Core Storage 

Mnemonics, 

Compass, D-1 

Peripheral Processor, 4-10 

Central Processor, 3-23 
Mode, 

Dot (system console), 6-4 

Exit, 3-11 
Modes, address '(Peripheral PrDcessor)i 4-6 



Range definitions, 3-17 
Range faults, 2-3 
Real-time clock, 4-3, 4-39 
Reference address, 2-2 
Registers, Central Processor 

address (A), 3-2, 3-6, 3-7, 3-9 

Increment (B), 3-2, 3-6, 3-7, 3-9 

operand, 3-2, 3-6, 3-7, 3-9 

Program Address (P), 3-8 
Registers, Peripheral and Control Processors, 

arithmetic (A), 4-8 

K register, 4-9 

Program Address (P), 4-9 

Q register, 4-9 
Relative memory address, 2-3 
Reservation Control, 

Register, B-13 
Bounding, 3-16 



Normalizing, 3-16, 3-34 



Operands, 

examples of, :3-25 
indefinite, 3-16 
infinite, 3-16 

Output, 4-38 



P register. 

Central Processor, 3-8 

Peripheral and Control Processor, 4-9 
Peripheraland Control Processors, 1-1, 1-2, 

access to Central Memory, 4-32 

adders, 4-4 

address modes, 4-6 

barrel, 4-4 
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Satellite Coupler, 1-3 
Single precision, 3-16 
Slot, 4-4 

Status channel and equipment, 
/Stops, Central Processor, 

flowchart, 3-14 

illegal packing (6400), 3-6 
Stunt box, 2-1 
System, computer, 

characteristics summary, 

description, 1-1 

hardware options, 1-8 
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1-4, 1-5, 1-6, 1-7 



Tags, -2-2 

X register. Central Processor, 3-6, 3-7 
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INDEX TO PERIPHERAL AND CONTROL PROCESSOR INSTRUCTIONS 



NUMERICAL 



OCTAL MNE- AD- 
CODE MONIC DIIESS 



00 


PSN 




01 


LJM 


md 


02 


RJM 


md 


03 


U.TN 


d 


04 


Z.IN 


d 


05 


NJN 


d 


OG 


PJiS! 


d 


07 


MJN 


d 


10 


SHN 


d 


11 


LMN 


d 


12 


DPN 


d 


13 


SCN 


d 


14 


LDN 


d 


15 


LCN 


d 


16 


ADN 


d 


17 


SBN 


d 


20 


LDC 


dm 


21 


ADC 


dm 


22 


LPC 


dm 


23 


LMC 


dm 


24 


PSN 




25 


PSN 




26 


EXN 




261* 


MXN 




27 


RPN 




30 


LDD 


d 


31 


ADD 


d 


32 


SBD 


d 


33 


LMD 


d 


34 


STD 


d 


35 


RAD 


d 


36 


AOD 


d 


37 


SOD 


d 


40 


LDI 


d 


41 


ADI 


d 


42 


SBI 


d 


43 


LMI 


d 


44 


STI 


d 


45 


RAI 


d 


46 


AOI 


d 


47 


SOI 


d 


50 


LDM 


md 


51 


ADM 


md 


52 


SBM 


md 


53 


LMM 


md 


54 


STM 


md 


55 


RAM 


md 


56 


ACM 


md 


57 


SOM 


md 


60 


CHD 


d 


61 


CRM 


md 


62 


CWD 


d 


63 


CWM 


md 


64 


AJM 


md 


65 


IJM 


md 


66 


FJM 


md 


67 


E.IM 


md 


70 


IAN 


d 


71 


lAM 


md 


72 


OAN 


d 


73 


OAM 


md 


74 


ACN 


d 


75 


DCN 


d 


76 


FAN 


d 


77 


PNC 


md 



Pass 

Long jump to m + (d) 

Return jump to m + (d) 

Unconditional jump d 

Zero jump d 

Nonzero jump d 

Plus jump d 

Minus jump d 

Shift d 

Logical difference d 

Logical product d 

Selective clear d 

Load d 

Load complement d 

Add d 

Subtract d 

Load dm 

Add dm 

Logical product dm 

Logical difference dm 

Pass 

Pass 

Exchange jump 

Monitor Exchange jump 

Read program address 

Load (d) 
Add (d) 

Subtract (d) 

Logical difference (d) 

Store (d) 

Replace add (d) 

Replace add one (d) 

Replace subtract one (d) 

Load ((d)) 

Add {(d)) 

Subtract ((d)) 

Logical difference ((d)) 

Store ((d)) 

Replace add ((d)) 

Replace add one ((d)) 

Replace subtract one ((d)) 

Load (m + (d)) 

Add (m + (d)) 

Subtract (m -t- (d)) 

Logical difference (m -f- (d)) 

Store (m + (d)) 

Replace add (m + (d)) 

Replace add one (m + (d)) 

Replace subtract one (m ■(■ (d)} 

Central read from (A) to d 

Central read (d) words from (A) to m 

Central write to (A) from d 

Central write (d) words to (A) from m 

Jump to m if channel d active 

Jump to m if channel d inactive 

Jimip to m if channel d full 

Jump to m if ciiannel d empty 

Input to A from channel d 

Input (A) words to m from channel d 

Output from A on channel d 

Output (A) words from m on ciiannel d 

Actii'ate channel d 

Disconnect channel d 

Function (A) on channel d 

Function m on channel d 
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-18 
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20 
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21 
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13 
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16 


4 


19 


4 


13 


4 


21 


4 


21 


4- 


22 


4- 


25 


4- 


25 


4- 


26 


4- 


27 


4- 


27 


4- 


28 


4- 


28 


4- 


28 


4- 


29 


4- 


29 


4- 


30 


4- 


30 


4- 


31 


4- 


31 


4- 


32 


4- 


32 



ALPHABETICAL 



MNE- OCTAL AD- 

MONIC CODE DRESS 



NAME 



-Included in 6700 or tliose Systems liaving the applicable Standard Options 



ACN 


74 


d 


ADC 


21 


dm 


ADD 


31 


d 


ADI 


41 


d 


ADM 


51 


md 


-4DN 


16 


d 


AJIVl 


64 


md 


.AOD 


36 


d 


AOI 


46 


d 


AOM 


56 


md 


CHD 


60 


d 


CRM 


61 


md 


CWD 


62 


d 


CWM 


63 


md 


DCN 


75 


d 


EJM 


67 


md 


EXN 


26 




FAN 


76 


d 


FJM 


66 


md 


FNC 


77 


md 


LAM- 


71 


md 


IAN 


70 


d 


IJM 


65 


md 


LCN 


15 


d 


LDC 


20 


dm 


LDD 


30 


d 


LDI 


40 


d 


LDM 


50 


md 


LDN 


14 


d- 


LJM 


01 


md 


LMC 


23 


dm 


LMD 


33 


d 


LMI 


43 


d 


LMM 


53 


md 


LMN 


11 


d 


LPC 


22 


dm 


LPN 


12 


d 


MJN 


07 


d 


MXN 


261* 




NJN 


05 


d 


OAM 


73 


md 


O.AN 


72 


d 


PJN 


06 


d 


PSN 


00 




PSN 


24 




PSN 


25 




RAD 


35 


d 


RAI 


45 


d 


RAM 


55 


md 


RJM 


02 


md 


RPN 


27 




SBD 


32 


d 


SBI 


42 


d 


SBM 


52 


md 


SBN 


17 


d 


SCN 


13 


d 


SUN 


10 


d 


SOD 


37 


d 


SOI 


47 


d 


SOM 


57 


md 


STD 


34 


d 


STI 


44 


d 


STM 


54 


md 


UJN 


03 


d 


ZJN 


04 


d 



Activate ciiannel d 

Add dm 

Add (d) 

Add ((d)) 

Add (m + (dj) 

Add d 

Jump to m if ciiannel d active 

Replace add one (d) 

Replace add one ({d)) 

Replace add one (m -r- (d)) 

Central read from (A) to d 

Central read (d) words from (A) to m 

Central write to (A) from d 

Central write (d) words to (A) from m 

Disconnect ciiannel d 

Jump to m if channel d empty 

Exchange jump 

Function (-A) on channel d 

Jump to m if channel d full 

Function m on channel d 

Input (A) words to m from channel d 

Input to A from channel d 

Jump to m if channel d inactive 

Load complement d 

Load dm 

Load (d) 

Load ((d)) 

Load (m -f- (d)) 

Load d 

Long jump to m + (d ) 

Logical difference dm 

Logical difference (d) 

Logical difference {(d)) 

Logical difference (m -f- (d)) 

Logical difference d 

Logical product dm 

Logical product d 

Minus jump d 

Monitor Exchange jump 

Nonzero jump d 

Output (A ) words from m on channel d 

Output from A on channel d 

Plus jump d 

Pass 

Pass 

Pass 

Replace add (d) 

Replace add {(d)) 

Replace add (m + (d)) 

Return jump to M + (d) 

Read program address 

Subtract (d) 

Subtract ((d)) 

Subtract (m + (d)) 

Subtract d 

Selective clear d 

Shift d 

Replace subtract one (d) 

Replace subtract one ((d)) 

[Replace subtract one (m + (d)) 

Store (d) 

Store ((d)) 

Store (m + (d)) 

Unconditional jump d 

Zero jump d 
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